|
首先一個(gè)實(shí)際的頁面中往往是會(huì)有較多的內(nèi)容,我們暫時(shí)把它分為A,B兩個(gè)區(qū)域,A區(qū)域是內(nèi)容區(qū)域,我們可以用updatepanel來實(shí)現(xiàn)異步刷新,B區(qū)域是上傳區(qū)域,我們用div已經(jīng)ifame占位,其中上傳的具體功能實(shí)現(xiàn)我們可以放到C頁面中,這樣當(dāng)點(diǎn)擊按鈕刷新B區(qū)域的時(shí)候,我們可以向C頁面?zhèn)髦祦砀吕锩娴膬?nèi)容,同樣當(dāng)我們點(diǎn)擊按鈕刪除或者保存內(nèi)容時(shí),也可以獲取C頁面中的內(nèi)容,這樣就基本上滿足了無刷新的感覺。
其實(shí)這種方式并不能稱之為異步刷新,因?yàn)槲覀冎皇怯胕frame來實(shí)現(xiàn)頁面的局部刷新從而滿足一種無刷新的感覺而已。
如果這樣處理的話,ASP.NET頁面與iframe之間的傳值就會(huì)成為另一個(gè)問題,其實(shí)這個(gè)問題如果你知道,就會(huì)比較簡單,但是不知道的話,就有點(diǎn)無從下手。
網(wǎng)上可能也提供了很多方案處理傳值,我使用的是使用Javascript來獲取控件從而取到他里面所包含的值。
這個(gè)是獲取iframe f1,以及頁面C中的 img控件
var objFrame = document.getElementById("f1");
var objPicture = objFrame.contentWindow.document.getElementById("imgPicture");
當(dāng)然你也可以在頁面C中去獲取父頁面的控件,從而獲取值
var objHid = this.parent.document.getElementById("")
這個(gè)是包含ifrmae的div
<div id="iconpicture">
<iframe id="f1" style="width: 300px; height: 300px" src="UploadImage.ASPx" scrolling="no"
frameborder="0" border="0" frameborder="no"></iframe>
</div>
這個(gè)實(shí)現(xiàn)方式我已經(jīng)在項(xiàng)目中成功的使用了,其實(shí)如果這樣處理主要的難點(diǎn)已經(jīng)不再于具體功能的實(shí)現(xiàn),而在于頁面的布局在多瀏覽器下的適應(yīng)了。當(dāng)然我提供的這些Javascript 是滿足多瀏覽器的。
AspNet技術(shù):asp.net 文件上傳與刷新與asp.net頁面與iframe之間的數(shù)據(jù)傳輸,轉(zhuǎn)載需保留來源!
鄭重聲明:本文版權(quán)歸原作者所有,轉(zhuǎn)載文章僅為傳播更多信息之目的,如作者信息標(biāo)記有誤,請(qǐng)第一時(shí)間聯(lián)系我們修改或刪除,多謝。