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

 


<%@ 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 = "你好!";
    }
}
  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
要获取后台C#变量和后台方法,可以使用AJAX或者SignalR等技术实现异步通信。 使用AJAX获取后台C#变量的步骤如下: 1. 在后台C#代码中定义一个公共变量,在需要获取的地方返回该变量的值。 2. 在前端JavaScript代码中使用XMLHttpRequest对象向后台发送请求,获取变量的值。 例如,假设后台定义了一个公共变量varName,需要在前端获取该变量的值: 后台代码: ``` public string varName = "Hello World!"; protected void Page_Load(object sender, EventArgs e) { // ... } [WebMethod] public string GetVarName() { return varName; } ``` 前端JavaScript代码: ``` var xhr = new XMLHttpRequest(); xhr.onreadystatechange = function() { if (xhr.readyState == 4 && xhr.status == 200) { var varName = xhr.responseText; console.log(varName); } }; xhr.open("POST", "Default.aspx/GetVarName", true); xhr.setRequestHeader("Content-Type", "application/json"); xhr.send(); ``` 使用AJAX调用后台方法的步骤如下: 1. 在后台C#代码中定义一个公共方法,使用[WebMethod]特性标记该方法。 2. 在前端JavaScript代码中使用XMLHttpRequest对象向后台发送请求,调用方法。 例如,假设后台定义了一个公共方法GetMessage,需要在前端调用方法并获取返回值: 后台代码: ``` [WebMethod] public string GetMessage() { return "Hello World!"; } ``` 前端JavaScript代码: ``` var xhr = new XMLHttpRequest(); xhr.onreadystatechange = function() { if (xhr.readyState == 4 && xhr.status == 200) { var message = xhr.responseText; console.log(message); } }; xhr.open("POST", "Default.aspx/GetMessage", true); xhr.setRequestHeader("Content-Type", "application/json"); xhr.send(); ``` 以上是使用AJAX获取后台C#变量和调用后台方法的基本步骤,具体实现需要根据具体业务场景和技术架构进行调整和优化。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值