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

本文介绍了一种不使用AJAX的情况下,从前台JavaScript调用后台C#方法的技巧。通过设置一个隐藏按钮并利用JS模拟点击事件,触发ASP.NET页面上的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 = " 你好,何奎! " ;
     }

}

转自: http://hi.baidu.com/panshuaiyang/blog/item/d5624606044f5a7d0308812f.html

转载于:https://www.cnblogs.com/Monday/archive/2009/04/23/1442193.html

评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符  | 博主筛选后可见
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值