在.aspx.cs(後台)中對aspx控制項綁定前台Javascript函數的幾種方法

來源:互聯網
上載者:User

最近中途接手了一個項目,做web開發,用的技術是aspx.net,可是真的做起來,覺得非常彆扭,原因在於有很多功能其實在前台可以處理的,但是因為用到了很多webcontrol,導致不斷postback。如果利用ajax來處理可能會好些。目前只能通過在後台對這些控制項綁定前台的javascript函數來支援前台的處理函數。在網上找了找,發現了幾種方法可以達到要求:

第一種,感覺用起來最方便

Button1.Attributes.Add("onclick", "return OnBtnClick()"); 
“OnBtnClick() “是一個前台方法,在此方法中直接在前台處理資料。可以替換成一般的指令碼

 

第二種,OnClientClick

<asp:Button ID="Button1" runat="server" Text="Button"  OnClientClick="OnClientClick()" OnClick="Button1_Click"  />
Button1_Click是在cs中(後台)處理的方法,而OnClientClick() 就是javascript(前台)的處理函數。

 

第三種 用ClientScript類動態添加指令碼

    用法如下:在想調用某個javascript指令碼函數的地方添加代碼,注意要保證MyFun已經在指令檔中定義過了。

    ClientScript.RegisterStartupScript(ClientScript.GetType(), "myscript", "<script>MyFun();</script>");

這個方法比Response.Write更方便一些,可以直接呼叫指令碼檔案中的自訂函數。

 

第四種,ClientScript.RegisterStartupScript
例子:StringBuilder sb = new StringBuilder();
        sb.Append("<script language='javascript'>");
        sb.Append("Button2_onclick('" + serverPath + "')");
        sb.Append("</script>");
        ClientScript.RegisterStartupScript(this.GetType(), "LoadPicScript", sb.ToString());

第五種. 用Response.Write方法寫入指令碼

比如在你單擊按鈕後,先操作資料庫,完了後顯示已經完成,可以在最後想調用的地方寫上
Response.Write("<script type='text/javascript'>alert();</script>");

這個方法有個缺陷就是不能呼叫指令碼檔案中的自訂的函數,只能調用內建函式,具體調用自訂的函數只能在Response.Write寫上函數定義,比如Response.Write("<script type='text/javascript'>function myfun(){...}</script>");

這種方法不斷可以從後台綁定前台的方法,還可以從cpp語言環境中綁定前台的方法

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在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.