在atlas裡面的UpdatePanel控制項中調用javascript,以及updatePanel的一些原理

來源:互聯網
上載者:User
在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" + ">";

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.