天天看点

不用AJAX实现前台JS调用后台C#方法(小技巧)

纯属小技巧,高手见笑了。

一提到如何在前台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页:

不用AJAX实现前台JS调用后台C#方法(小技巧)
不用AJAX实现前台JS调用后台C#方法(小技巧)

<%

不用AJAX实现前台JS调用后台C#方法(小技巧)

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

不用AJAX实现前台JS调用后台C#方法(小技巧)
不用AJAX实现前台JS调用后台C#方法(小技巧)

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.1//EN" "http://www.w3.org/TR/xhtml11/DTD/xhtml11.dtd">

不用AJAX实现前台JS调用后台C#方法(小技巧)

<html xmlns="http://www.w3.org/1999/xhtml">

不用AJAX实现前台JS调用后台C#方法(小技巧)

<head runat="server">

不用AJAX实现前台JS调用后台C#方法(小技巧)

    <title>Untitled Page</title>

不用AJAX实现前台JS调用后台C#方法(小技巧)
不用AJAX实现前台JS调用后台C#方法(小技巧)
不用AJAX实现前台JS调用后台C#方法(小技巧)

    <script>

不用AJAX实现前台JS调用后台C#方法(小技巧)
不用AJAX实现前台JS调用后台C#方法(小技巧)

    function go()

不用AJAX实现前台JS调用后台C#方法(小技巧)
不用AJAX实现前台JS调用后台C#方法(小技巧)
不用AJAX实现前台JS调用后台C#方法(小技巧)

{

不用AJAX实现前台JS调用后台C#方法(小技巧)

        document.getElementById("Button2").click();

不用AJAX实现前台JS调用后台C#方法(小技巧)

    }

不用AJAX实现前台JS调用后台C#方法(小技巧)

    </script>

不用AJAX实现前台JS调用后台C#方法(小技巧)
不用AJAX实现前台JS调用后台C#方法(小技巧)

</head>

不用AJAX实现前台JS调用后台C#方法(小技巧)

<body>

不用AJAX实现前台JS调用后台C#方法(小技巧)

    <form id="form1" runat="server">

不用AJAX实现前台JS调用后台C#方法(小技巧)

        <div>

不用AJAX实现前台JS调用后台C#方法(小技巧)

            <asp:TextBox ID="TextBox1" runat="server"></asp:TextBox>

不用AJAX实现前台JS调用后台C#方法(小技巧)

            <asp:Button ID="Button1" runat="server" Text="Button" OnClientClick="go();return false;" />

不用AJAX实现前台JS调用后台C#方法(小技巧)

            <asp:Button ID="Button2" runat="server" Text="Button" OnClick="Button2_Click" Style="display: none;" />

不用AJAX实现前台JS调用后台C#方法(小技巧)

        </div>

不用AJAX实现前台JS调用后台C#方法(小技巧)

    </form>

不用AJAX实现前台JS调用后台C#方法(小技巧)

</body>

不用AJAX实现前台JS调用后台C#方法(小技巧)

</html>

不用AJAX实现前台JS调用后台C#方法(小技巧)

后台C#:

不用AJAX实现前台JS调用后台C#方法(小技巧)

using System;

不用AJAX实现前台JS调用后台C#方法(小技巧)

using System.Data;

不用AJAX实现前台JS调用后台C#方法(小技巧)

using System.Configuration;

不用AJAX实现前台JS调用后台C#方法(小技巧)

using System.Web;

不用AJAX实现前台JS调用后台C#方法(小技巧)

using System.Web.Security;

不用AJAX实现前台JS调用后台C#方法(小技巧)

using System.Web.UI;

不用AJAX实现前台JS调用后台C#方法(小技巧)

using System.Web.UI.WebControls;

不用AJAX实现前台JS调用后台C#方法(小技巧)

using System.Web.UI.WebControls.WebParts;

不用AJAX实现前台JS调用后台C#方法(小技巧)

using System.Web.UI.HtmlControls;

不用AJAX实现前台JS调用后台C#方法(小技巧)

using System.Text;

不用AJAX实现前台JS调用后台C#方法(小技巧)
不用AJAX实现前台JS调用后台C#方法(小技巧)

public partial class _Default : System.Web.UI.Page 

不用AJAX实现前台JS调用后台C#方法(小技巧)
不用AJAX实现前台JS调用后台C#方法(小技巧)
不用AJAX实现前台JS调用后台C#方法(小技巧)
不用AJAX实现前台JS调用后台C#方法(小技巧)

    protected void Page_Load(object sender, EventArgs e)

不用AJAX实现前台JS调用后台C#方法(小技巧)
不用AJAX实现前台JS调用后台C#方法(小技巧)
不用AJAX实现前台JS调用后台C#方法(小技巧)
不用AJAX实现前台JS调用后台C#方法(小技巧)
不用AJAX实现前台JS调用后台C#方法(小技巧)
不用AJAX实现前台JS调用后台C#方法(小技巧)
不用AJAX实现前台JS调用后台C#方法(小技巧)
不用AJAX实现前台JS调用后台C#方法(小技巧)

    protected void Button2_Click(object sender, EventArgs e)

不用AJAX实现前台JS调用后台C#方法(小技巧)
不用AJAX实现前台JS调用后台C#方法(小技巧)
不用AJAX实现前台JS调用后台C#方法(小技巧)
不用AJAX实现前台JS调用后台C#方法(小技巧)

        this.SayHello();

不用AJAX实现前台JS调用后台C#方法(小技巧)
不用AJAX实现前台JS调用后台C#方法(小技巧)
不用AJAX实现前台JS调用后台C#方法(小技巧)

    private void SayHello()

不用AJAX实现前台JS调用后台C#方法(小技巧)
不用AJAX实现前台JS调用后台C#方法(小技巧)
不用AJAX实现前台JS调用后台C#方法(小技巧)
不用AJAX实现前台JS调用后台C#方法(小技巧)

        this.TextBox1.Text = "你好,何奎!";

不用AJAX实现前台JS调用后台C#方法(小技巧)
不用AJAX实现前台JS调用后台C#方法(小技巧)

}

继续阅读