在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" + ">";