未使用PageMethods调用方法背后的代码

Code behind method not being called using PageMethods

本文关键字:代码 背后 方法 PageMethods 调用 未使用      更新时间:2023-09-26

我试图调用一个非常简单的代码背后c#方法使用PageMethods (AJAX)。我有EnablePageMethods = true,并有我的代码背后的方法作为WebMethod公共静态。我尝试了ScriptMethod与WebMethod,但没有工作。我试着改变配置文件,但没有运气。

 <script type="text/javascript">
    function ShowAvailability() {
        PageMethods.btnCheck_Click(document.getElementById("<%=txtUserName.ClientID%>").value, OnSuccess)
    };
            function OnSuccess(response) {
                alert("On Success");
                var mesg = document.getElementById("mesg");
                switch (response) {
                    case "true":
                        mesg.style.color = "green";
                        mesg.innerHTML = "Available";
                        break;
                    case "false":
                        mesg.style.color = "red";
                        mesg.innerHTML = "Not Available";
                        break;
                    case "error":
                        mesg.style.color = "red";
                        mesg.innerHTML = "Error occured";
                        break;
                }
            }
            function OnChange(txt) {
                document.getElementById("mesg").innerHTML = "";
            }
            function test()
            {              
            }
</script>
<form id="form1" runat="server">
    <asp:ScriptManager ID="sm" EnablePageMethods="true" EnablePartialRendering="true" runat="server" />
<div>
        UserName :
<asp:TextBox ID="txtUserName" runat="server"
    onkeyup="OnChange(this)"></asp:TextBox>
        <%--<asp:Button ID="btnCheck" runat="server" Text="Show Availability"  OnClientClick="btnCheck_Click(), return false;"></asp:Button>--%>
        <br />
        <button id="btncheck" onclick="ShowAvailability()">Show Availability</button>
        <span id="mesg"></span>
    </div>
</form>

使用OnClientClick,你不能调用代码后面的方法,它将调用名为btnCheck_Click的脚本函数。

Use this-

    <asp:Button ID="btnSearch" runat="server" ClientIDMode="Static" Text="Search" CssClass="button" OnClick="btnSearch_Click" />

和同一页面后面的代码使用-

  protected void btnSearch_Click(object sender, EventArgs e)
    {
       //your code
    }

,以防您想使用ajax。然后在客户端声明-

Use this-

<asp:Button ID="btnSearch" runat="server" ClientIDMode="Static" Text="Search" CssClass="button" OnClientClick="btnSearch_Click()" />

和Script标签中调用ajax

function btnSearch_Click()
    { 
       jQuery.ajax({
                url: "Dashboard.aspx/getUserDetails", /* getUserDetails is a web method */
                type: "POST",
                data: jsondata,  /* jsondata= passed parameter in json format */
                contentType: "application/json; charset=utf-8",
                dataType: "json",
                success: function (data) { },
                error: function () {
                    $('#Loadingimage').hide();
                    jAlert("Please try again later", 'Moderators');
                }
             });
    }

并在Dashboard.aspx.cs中编写以下代码

     [WebMethod]
    public static String getUserDetails(string strUserId)
    {
      return "";    /* for string only */
    }