`

JS调用CS里的方法:PageMethods

阅读更多
来源于:http://hi.baidu.com/haofz1983/item/a2b657378953a5342f20c45f

原来是通过PageMethods来实现的。

举个列子:

Default.aspx 里代码

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

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">

<html xmlns="http://www.w3.org/1999/xhtml">
<head runat="server">
<title>无标题页</title>
<script type="text/javascript" language="javascript">
<!--
function minbzdm()
{
PageMethods.OK(xxx);
}
function xxx(result)
{
alert(result);
}
//-->
</script>
</head>
<body>
    <form id="form1" runat="server">
    <asp:ScriptManager ID="ScriptManager1" runat="server" EnablePageMethods="true">
    </asp:ScriptManager>
    <div>
    <input type='button' value='删除' onclick='minbzdm()' />
    </div>
    </form>
</body>
</html>

Default.aspx.cs里的代码

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

     [System.Web.Services.WebMethod]
    public static string OK()
     {
        return "OK";
     }
}

通过PageMethods方法来实现JS调用CS,必须注意一下几点:

【1】静态的方法

          public static


【2】需要在cs方法上加上:

         [System.Web.Services.WebMethod]


【3】需要自定义一个函数接受结果

        function xxx(result)
        {
        alert(result);
        }


【4】ScriptManager 必须设置成 EnablePageMethods="true"

注意:

1、PageMethods.OK( 参数一,参数二,参数三,...,xxx);可以传入参数。对应的CS后台方法也要改进!

2、xxx为回调函数名,只有仅有一个参数。参数可以是数组,List<T>泛型等。

http://www.cnblogs.com/juxiaoqi/archive/2008/08/21/1273059.html
补充:

AJAX 调用Web Service 与 PageMethods注意细节

想要使用ASP.NET AJAX在客户端JavaScript中异步调用服务器端Web Service,我们需要:

1 为Web Service类或需要暴露给客户端的Web Service方法添加[ScriptService]
      属性;

2 为Web Service中需要暴露给客户端的方法添加[WebMethod]属性;

3 在页面中的ScriptManager控件中添加对该Web Service的引用;

4 在客户端使用如下JavaScript语法调用该Web Service:
      [NameSpace].[ClassName].[MethodName](param1, param2,..., callbackFunction)

5 为客户端异步调用指定回调函数,在回调函数中接收返回值并进一步处理。


-----------------------

想要使用ASP.NET AJAX在客户端JavaScript中异步调用定义在ASP.NET页面中的方法,我们需要:

1 将该方法声明为公有(public);

2 将该方法声明为类方法(C#中的static,VB.NET中的Shared),而不是实例方法;

3 为该方法添加[WebMethod]属性;

4 将页面中ScriptManager控件的EnablePageMethods属性设置为true;

5 在客户端使用如下JavaScript语法调用该页面方法:
      PageMethods.[MethodName](param1, param2,..., callbackFunction);

6 为客户端异步调用指定回调函数,在回调函数中接收返回值并进一步处理。

补充:另外一种调用


前台JS:

function check() {

            var title = document.getElementById("TabContainer1_tabpanel4_txtPicTitle").value;

            var sn = document.getElementById("TabContainer1_tabpanel4_txtSN").value;

            var playGUID = document.getElementById("TabContainer1_tabpanel4_hidPlayGUID").value;

            var msg = Drilling_Pictures.Validate(title, sn, playGUID).value;//主要注意这里

            if (msg == "") {

                return true;

            } else {

                alert(msg);

                return false;

            }

        }

<asp:ImageButton ID="imgBtn" runat="server" ImageUrl="~/images/btn25.png" OnClick="imgBtn_Click"

                                                                OnClientClick="return check();" />


后台代码:

public partial class Drilling_Pictures : BasePage

{

    [AjaxPro.AjaxMethod]

    public string Validate(string title, string sn, string playGUID)

    {

        string str = "";

        if (title.Trim() == "")

        {

            str = "标题不能为空";

        }

        else if (sn.Trim() == "")

        {

            str = "序号不能为空";

        }

        else if (!ConvertInt(sn.Trim()))

        {

            str = "序号必须为整数";

        }

        else if (!new DrillingPlayBack().CheckSN(playGUID, int.Parse(sn)))

        {

            str = "序号已经存在";

        }

        return str;

    }

}
分享到:
评论

相关推荐

    客户端脚本调用服务端静态方法----PageMethods.doc

    PageMethods是ASP.NET AJAX框架提供的一种机制,它使得客户端JavaScript能够直接调用服务端的方法而无需创建额外的WebService或WebAPI接口。这种方式简化了前端与后端之间的交互逻辑,提高了开发效率。 #### 三、...

    .net js调用cs带参数代码

    下面,我们将详细探讨如何在.NET环境中实现JS调用CS带参数的方法,并确保这一过程具有返回值。 ### JS调用CS带参数的步骤 #### 步骤1:定义Web方法 首先,在C#后端代码中,我们需要定义一个Web方法,以便前端...

    cs中调用js函数.docx

    JavaScript调用C#函数 #### 1.1 使用`__doPostBack`方法 这是ASP.NET中最常见的方法,通过`__doPostBack`函数触发服务器端事件,从而调用C#中的函数。例如: ```html &lt;input type="button" onclick="javascript:__...

    cs类中如何用callbackReslt类调用主页中的自定义的JavaScript函数

    在.NET开发环境中,C#(简称cs)类与JavaScript交互是一个常见的需求,特别是在Web应用程序中。CallbackResult类是ASP.NET AJAX框架提供的一种机制,用于在服务器端代码(C#)和客户端代码(JavaScript)之间传递...

    c# webform js文件获取客户端控件,后台cs获取前台客户端控件的值,c#和js的交互

    在C# WebForm应用中,JavaScript(JS)与C#(CS)的交互是常见的需求,主要用于处理客户端的动态事件和数据验证。本教程将详细讲解如何使用JS获取客户端控件的值,并在C#后台代码(CS)中获取这些前端输入的数据。...

    asp.net下PageMethods使用技巧

    4. **JavaScript调用**:在客户端,可以通过jQuery或其他JavaScript库来调用PageMethods。例如,使用jQuery的$.ajax或者$.pageMethod(如果使用ASP.NET AJAX Control Toolkit): ```javascript $.ajax({ type: ...

    从ASP页面调用函数背后的代码

    然后,您可以在JavaScript中通过`PageMethods.MyServerMethod`来调用服务器端的方法。 2. **WebMethods**: WebMethods是ASP.NET页面类中的公共静态方法,它们标记有`[WebMethod]`属性。这些方法可以直接通过Ajax...

    Ajax无刷新开发控件

    4. **PageMethods和WebServices**:在.NET中,可以通过定义PageMethods或创建WebServices来提供Ajax调用的服务端方法。这些方法可以处理来自客户端的Ajax请求,执行业务逻辑,并返回结果数据。 5. **JavaScript和...

    ASP.NET常用的JS代码

    在提供的文件`JSCode.cs`中,很可能包含了上述提到的一些JavaScript方法和函数的C#实现,用于在ASP.NET页面中嵌入或调用。这些代码可能包括对DOM的操作、事件处理函数的定义、以及与服务器端的交互逻辑。通过理解...

    textbox绑定回车

    为了在回车键被按下时执行服务器端的代码,我们需要在JavaScript中处理这个事件并调用PageMethods或WebMethods。在HTML部分添加一个ScriptManager控件,然后定义一个JavaScript函数: ```html &lt;asp:ScriptManager ...

    asp.net中TextBox获得焦点和失去焦点——客户端JavaScript事件

    在这个例子中,我们使用了jQuery的`on()`方法绑定`blur`事件,并调用服务器端的`PageMethod`进行验证。如果验证通过,`OnSuccess`函数会被调用;否则,`OnError`函数会被调用。 总结来说,ASP.NET中的TextBox可以...

    如何:实现ICallBackEventHandler(从客户端调用服务器端代码)

    在客户端,使用JavaScript调用PageMethods的静态方法,这是通过`ScriptManager`启用的。例如,假设我们有一个Button控件,当点击时触发回调: ```html 触发回调" onclick="callServerMethod();" /&gt; ``` 然后,在...

    自己写的ajax例子

    这些方法通常是静态的,可以直接从JavaScript调用,处理完数据后返回JSON或XML格式的结果,便于前端解析和显示。 `areal.ascx.cs`中的代码可能涉及到更具体的业务逻辑,比如验证用户输入,处理数据库操作等。它可以...

    asp.net的ajax代码例子

    这是一个简单的JavaScript调用示例: ```javascript function callServerMethod() { PageMethods.MyServerMethod(function(result) { // 在这里处理返回的结果 alert('Server returned: ' + result); }, ...

    一个基于ASP.NET AJAX+JavaScript 实现的WCF service 服务程序源码例子

    // JavaScript调用WCF服务 function callService() { PageMethods.GetData(function(result) { // 处理返回数据 var data = JSON.parse(result); console.log(data); }, function(error) { // 处理错误 alert...

    asp.net ajax简单例子

    前端JavaScript通常使用ASP.NET AJAX的`PageMethods`对象或`$.ajax`(如果使用jQuery)来发起AJAX调用。这些调用会发送HTTP请求到服务器,处理响应,并根据需要更新DOM。 总的来说,这个"asp.net ajax简单例子"展示...

    jquery ajax用json传值实例asp.net

    例如,如果使用PageMethods,你可以在代码-behind文件(如.aspx.cs)中定义一个公共静态方法: ```csharp [WebMethod] public static void YourMethodName(string key1, string key2) { // 处理key1和key2的逻辑 }...

    Flash与C#交互全集(bs与cs).rar

    在B/S场景下,JavaScript可以调用Web服务或PageMethods,C#端处理后返回结果,JavaScript再将这些结果传递给Flash。而在C/S模式下,如果需要直接与C#应用程序通信,可能需要通过ActiveX或NPAPI插件来实现,这通常...

    ICallbackEventHandler接口实现多级联动

    2. **实现接口**:在代码-behind文件(如`Default3.aspx.cs`)中,让页面类继承`ICallbackEventHandler`接口并实现其方法。 ```csharp public partial class Default3 : System.Web.UI.Page, ICallbackEventHandler...

Global site tag (gtag.js) - Google Analytics