在atlas里面有UpdatePanel控件,支持局部更新,只要指名Mode="Conditional",當然,Scr 局部更新,使用的是xmlHttp。過程如下: 由此看來,所謂局部跟新就是只把指定的updatePanel的部分重新繪制(回發服務器的時候是整個頁面都要回發的;后臺代碼也是和以前一樣每一個都會處理;但是處理的結果只有部分被返回到客戶端)。 這樣一來,如果你想在UpdatePanle處理的時候順便引發一個頁面的js處理就很困難了。因為你回發的數據全部被更新到了一個小角落,以前的Response.Write(js)根本不起作用。 解決的方法是這樣的: 其實執行也不是那么順利,因為atlas在執行局部跟新之后,會把頁面上所有的js都放到一起---多管閑事---所以會造成一些小影響:很多js都有諸如<!-之類的注釋符號,一不小心,你自己的js也會被注釋起來。這個的確比較麻煩。
1:postback的時候,頁面的js把頁面上數據postback(是整個頁面都要postback的)
2:后臺接收到請求,開始處理(頁面的pageLoad什么的都可以觸發了)
3:處理完畢之后,只把要更新的數據發回到頁面(根據你要更新的UpdatePanel的名稱來確定回發那一部分數據。就是this.updatePanelXX.Update()那一句代碼了)
4:頁面(客戶端)只對這一部分回發數據進行更新(這就是所謂的局部更新,方法就是找到updatePanle,然后UpdatePanel.InnerHtml=PostBackData。就是一個直接替換。)
this.Page.ClientScript.RegisterStartupScript(this.GetType(), "OpenOverViewPart", openScript);使用RegisterStartupScript方法來注冊js函數,然后就可以順利執行。
解決的辦法比較下X,需要自己控制一下js輸出的風格,多加幾個回車換行,以示不屬于注釋
string openScript = "/n/t";
openScript = "<script" + " type='text/javascript'>/r/n"
+ "/r/n"
+ "var a=0;/r/n"
+ "opener.top.__doPostBack('" + Request.Params["refresh"] + "','refresh');/r/n"
+ "window.opener.focus();"
+ "window.close();"
+ "<" + "/script" + ">";
新聞熱點
疑難解答