不用AJAX實現前台JS調用後台C#方法(小技巧)

來源:互聯網
上載者:User

純屬小技巧,高手見笑了。

一提到如何在前台JS調用後台C#方法,AJAX成為了必然的想法。
只是實現的細節採用AJAX 1.0或者AjaxPro的區別。
其實如果不用AJAX,我們也能夠很方便地利用JS調用後台方法。

步驟如下:
1 前台放一個按鈕。設定為隱藏。注意:不能直接設定Visible=false的方式,這樣的話在ASP.Net 2.0編譯後的代碼裡是找不到這個按鈕的。需要設定風格:style="display:none;"
2 雙擊按鈕,寫入C#方法,或者寫一個調用後台其他方法的程式碼片段
3 前台JS調用的時候,照如下寫,這樣可以類比按鈕的點擊事件,觸發後台方法:
document.getElementById("Button2").click();

樣本
ASP.Net頁:

<%@ Page Language="C#" AutoEventWireup="true" CodeFile="Default.aspx.cs" Inherits="_Default" %>

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.1//EN" "http://www.w3.org/TR/xhtml11/DTD/xhtml11.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head runat="server">
    <title>Untitled Page</title>

    <script>
    function go()
    {
        document.getElementById("Button2").click();
    }
    </script>

</head>
<body>
    <form id="form1" runat="server">
        <div>
            <asp:TextBox ID="TextBox1" runat="server"></asp:TextBox>
            <asp:Button ID="Button1" runat="server" Text="Button" OnClientClick="go();return false;" />
            <asp:Button ID="Button2" runat="server" Text="Button" OnClick="Button2_Click" Style="display: none;" />
        </div>
    </form>
</body>
</html>

後台C#:

using System;
using System.Data;
using System.Configuration;
using System.Web;
using System.Web.Security;
using System.Web.UI;
using System.Web.UI.WebControls;
using System.Web.UI.WebControls.WebParts;
using System.Web.UI.HtmlControls;
using System.Text;

public partial class _Default : System.Web.UI.Page 
{
    protected void Page_Load(object sender, EventArgs e)
    {

       
    }

    protected void Button2_Click(object sender, EventArgs e)
    {
        this.SayHello();
    }

    private void SayHello()
    {
        this.TextBox1.Text = "你好,何奎!";
    }
}

 

相關文章

聯繫我們

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