在ASP.NET WebForms中使用jQuery调用’WebMethod’

前端之家收集整理的这篇文章主要介绍了在ASP.NET WebForms中使用jQuery调用’WebMethod’前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
我在下面的WebMethod中设置了一个断点,但我从来没有遇到断点。

CS:

  1. [WebMethod]
  2. public static string search()
  3. {
  4. return "worked";
  5. }

ASPX:

  1. function search() {
  2. $.ajax({
  3. type: "POST",url: "ProcessAudit/req_brws.aspx/search",data: "{}",contentType: "application/json; charset=utf-8",dataType: "json",success: function (msg) {
  4. alert(msg)
  5. }
  6. });
  7. }
  1. <button id = "btnSearch" onclick = "search()" >Search</button>

解决方法

确保在ScriptManager元素中启用了页面方法
  1. <asp:ScriptManager ID="scm" runat="server" EnablePageMethods="true" />

并且您已通过在onclick处理程序中返回false取消了该按钮的默认操作,否则该页面将执行完整的回发,并且您的AJAX调用可能永远没有时间完成。这是一个完整的工作示例:

  1. <%@ Page Language="C#" %>
  2. <script type="text/c#" runat="server">
  3. [System.Web.Services.WebMethod]
  4. public static string search()
  5. {
  6. return "worked";
  7. }
  8. </script>
  9.  
  10. <!DOCTYPE html>
  11. <html>
  12. <head id="Head1" runat="server">
  13. <title></title>
  14. </head>
  15. <body>
  16. <form id="Form1" runat="server">
  17. <asp:ScriptManager ID="scm" runat="server" EnablePageMethods="true" />
  18. <button id="btnSearch" onclick="search(); return false;" >Search</button>
  19. </form>
  20.  
  21. <script type="text/javascript" src="http://ajax.googleapis.com/ajax/libs/jquery/1.6.2/jquery.min.js"></script>
  22. <script type="text/javascript">
  23. function search() {
  24. $.ajax({
  25. type: 'POST',url: '<%= ResolveUrl("~/default.aspx/search") %>',data: '{ }',contentType: 'application/json; charset=utf-8',dataType: 'json',success: function (msg) {
  26. alert(msg.d)
  27. }
  28. });
  29. }
  30. </script>
  31. </body>
  32. </html>

另一种可能性是不引人注意地订阅点击处理程序:

  1. <button id="btnSearch">Search</button>

然后在一个单独的javascript文件中:

  1. $('#btnSearch').click(function() {
  2. $.ajax({
  3. type: 'POST',success: function (msg) {
  4. alert(msg.d)
  5. }
  6. });
  7. return false;
  8. });

您可能还会注意到成功回调中msg.d属性的使用,ASP.NET使用它来包装整个响应,以及使用ResolveUrl方法正确生成页面方法的URL而不是硬编码。

猜你在找的asp.Net相关文章