在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 = "nt";
openScript = "<script" + " type='text/javascript'>rn"
+ "rn"
+ "var a=0;rn"
+ "opener.top.__doPostBack('" + Request.Params["refresh"] + "','refresh');rn"
+ "window.opener.focus();"
+ "window.close();"
+ "<" + "/script" + ">";