在atlas裡面有UpdatePanel控件,支持局部更新,只要指名Mode="Conditional",當然,ScriptManager也要設置EnablePartialRendering="true"。
局部更新,使用的是XMLHttp。過程如下:
1:postback的時候,頁面的JS把頁面上數據postback(是整個頁面都要postback的)
2:後台接收到請求,開始處理(頁面的pageLoad什麼的都可以觸發了)
3:處理完畢之後,只把要更新的數據發回到頁面(根據你要更新的UpdatePanel的名稱來確定回發那一部分數據。就是this.updatePanelXX.Update()那一句代碼了)
4:頁面(客戶端)只對這一部分回發數據進行更新(這就是所謂的局部更新,方法就是找到updatePanle,然後UpdatePanel.InnerHtml=PostBackData。就是一個直接替換。)
由此看來,所謂局部跟新就是只把指定的updatePanel的部分重新繪制(回發服務器的時候是整個頁面都要回發的;後台代碼也是和以前一樣每一個都會處理;但是處理的結果只有部分被返回到客戶端)。
這樣一來,如果你想在UpdatePanle處理的時候順便引發一個頁面的js處理就很困難了。因為你回發的數據全部被更新到了一個小角落,以前的Response.Write(JS)根本不起作用。
解決的方法是這樣的:
this.Page.ClientScript.RegisterStartupScript(this.GetType(), "OpenOverVIEwPart", openScript);使用RegisterStartupScript方法來注冊JS函數,然後就可以順利執行。
其實執行也不是那麼順利,因為atlas在執行局部跟新之後,會把頁面上所有的js都放到一起---多管閒事---所以會造成一些小影響:很多js都有諸如<!-之類的注釋符號,一不小心,你自己的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" + ">";