通过jQuery调用ASP.NET服务器端的方法
我试图通过jQuery从客户端调用服务器端方法。 我的代码如下:
服务器端:
using System.Web.Services; [WebMethod()] //[ScriptMethod()] public static void SendMessage(string subject, string message, string messageId, string pupilId) { //Send message }
客户端:
$("#btnSendMessage").live("click", function(){ var subject = $("#tbSubject").val(); var message = $("#tbMessage").val(); var messageId = $("#hdnMessageId").val(); var pupilId = $("#hdnPupilId").val(); $.ajax({ type: "POST", url: "./MessagePopup.aspx/SendMessage", data: ("subject=" + subject + "&message=" + message + "&messageId=" + messageId + "&pupilId=" + pupilId), error: function(XMLHttpRequest, textStatus, errorThrown){ alert(textStatus); }, success: function(result){ alert("success"); } }); return false; });
我已经在服务器端SendMessage方法中添加了一个断点,但是它从来没有打过它,但是当我运行代码时,jQuery成功方法被调用。 这可能是什么原因造成的?
要调用ASP.NET AJAX“ScriptServices”和页面方法,您需要使用完整的$ .ajax()语法:
$.ajax({ type: "POST", url: "MessagePopup.aspx/SendMessage", data: "{subject:'" + subject + "',message:'" + message + ",messageId:'" + messageId + "',pupilId:'" + pupilId +"'}", contentType: "application/json; charset=utf-8", dataType: "json", success: function(msg) { // Do something interesting here. } });
有关为什么这是必要的详细信息,请参阅此文章: http : //encosia.com/2008/05/29/using-jquery-to-directly-call-aspnet-ajax-page-methods/
编辑:扩展名不会更改为.asmx,但保持.aspx。
看起来你正在尝试使用页面方法。
在这里看看ASP.NET页面中的方法帮助
您应该使用Web服务,而不是常规的aspx网页。 网页不支持调用web方法,我相信你的jQuery请求会加载HTML页面。 我build议你两件事情:
- 使用Fiddler2(使用IE)或HttpFox(使用Firefox)来debugging客户端的AJAX请求和响应。
- 在服务器端使用WCF Web服务。 在这种情况下,您可以使用SvcConfigEditor和SvcTraceViewer来configuration和debugging服务器端的Web方法。
$.ajax({ type: "POST", url: "MessagePopup.aspx/SendMessage", data: "{subject:'" + subject + "',message:'" + message + ",messageId:'" + messageId + "',pupilId:'" + pupilId +"'}", async: true, cache: false, contentType: "application/json; charset=utf-8", dataType: "json", success: function() {}, error:function (xhr, ajaxOptions, thrownError){ alert(thrownError); } });
如果这不起作用…并给出“语法错误:语法错误”…然后添加此
<httpHandlers> <remove verb="*" path="*.asmx"/> <add verb="*" path="*.asmx" validate="false" type="System.Web.Script.Services.ScriptHandlerFactory, System.Web.Extensions, Version=3.5.0.0, Culture=neutral, PublicKeyToken=31BF3856AD364E35"/> <add verb="*" path="*_AppService.axd" validate="false" type="System.Web.Script.Services.ScriptHandlerFactory, System.Web.Extensions, Version=3.5.0.0, Culture=neutral, PublicKeyToken=31BF3856AD364E35"/> <add verb="GET,HEAD" path="ScriptResource.axd" type="System.Web.Handlers.ScriptResourceHandler, System.Web.Extensions, Version=3.5.0.0, Culture=neutral, PublicKeyToken=31BF3856AD364E35" validate="false"/> </httpHandlers> <httpModules> <add name="ScriptModule" type="System.Web.Handlers.ScriptModule, System.Web.Extensions, Version=3.5.0.0, Culture=neutral, PublicKeyToken=31BF3856AD364E35"/> </httpModules>
在你的Web.Config文件中</compilation>
和</system.web>
之间。
希望这将有助于某人,因为我花了一段时间来弄清楚除了jQuery的function,我不得不在Web.Config中添加。
这里是可能在你的情况下工作的代码。
<script type="text/javascript"> $(document).ready(function () { // Add the page method call as an onclick handler for the button. $("#btnSubmit").click(function () { //get the string from the textbox $.ajax({ type: "POST", url: "testSearch.aspx/GetMyShippingDate", contentType: "application/json; charset=utf-8", data: "{'tracking_num': '" + $("#txtTrackingNumber").val() + "'}", dataType: "json", success: function (date) { // Replace the div's content with the page method's return. Success(date); }, error: Failed }); }); }); function Success(result) { $("#ParcelShippingDate").html(result.d); } function Failed(result) { alert(result.status + " " + result.statusText); }
有一个例子总是为我工作。
这里是完整的文章http://www.webdeveloperpost.com/Articles/How-to-use-jquery-ajax-in-asp-dot-net-web-page.aspx
对于那些想要直接使用jQuery的asp.net方法callback的人来说,这是非常有效的