閱讀63 返回首頁    go 汽車大全


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

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

步驟如下:
1 前台放一個按鈕。設置為隱藏。注意:不能直接設置Visible=false的方式,這樣的話在ASP.Net 2.0編譯後的代碼裏是找不到這個按鈕的。需要設置風格:
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" "https://www.w3.org/TR/xhtml11/DTD/xhtml11.dtd">
<html xmlns="https://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 = "Hallo,Sinodier!";
    }

}
 

最後更新:2017-04-02 00:06:24

  上一篇:go VS2005常用插件搜羅(開發效率提高)
  下一篇:go Pro JavaScript Techniques第二章:麵向對象的Javascript