繁体   English   中英

jQuery,ajax POST方法成功返回:未定义

[英]jQuery, ajax POST method success returns: Undefined

我的脚本代码:

$('#btnSave').click(function() {
    var pageUrl = '<%= ResolveUrl("~/TestPage.aspx/SystemEdit")%>';
    var ip = $('#editIP').text();
    var loc = $('#txtBay').val();
    var team = $('#txtTeam').val();
    var port = $('#txtPort').val();
    var xcel = "", office = "", moni = "";                                   
    var parameter={ "ip": ip, "loc": loc, "team": team, "port": port, "excel": xcel, "office": office, "monitor": moni}

    $.ajax({
        type: 'POST',
        url: pageUrl,
        data: JSON.stringify(parameter),
        contentType: 'json',
        success: function(data) {
            alert(data);
        },
        error: function(data,success,error) {
            alert("Error:" +error);
        }
    });           
});

我在c#代码后面的代码是:

[WebMethod]
public static string SystemEdit(string ip, string loc,string team, string port, string excel,string office, string monitor)
{
    return "The Current Time is: "+ DateTime.Now.ToString();
}

我的页面名称是:TestPage.aspx

单击保存按钮时,我'未定义'。 我没有从c#后面的代码中获取当前时间。

你需要返回如下的json结果:

return JsonConvert.SerializeObject("The Current Time is: "+ DateTime.Now.ToString());

还将以下属性放在上面的方法:

[ScriptMethod(ResponseFormat = ResponseFormat.Json)]

当你指定json格式时,你应该写:

 contentType: "application/json; charset=utf-8",

顺便说一句,你应该在这里使用Webservice!

我想设置一个json内容类型应该这样做:

contentType: 'application/json',

如果您使用的是vs2013,请确保在route.config中禁用以下行以使其正常工作。

 'settings.AutoRedirectMode = RedirectMode.Permanent

我的VB代码背后:

  <WebMethod()>


       Public Shared Function GetReport(ByVal Data As String) As String
          Try

                Return "Hello" + Data

            Catch ex As Exception

                Return "Failed"
      End Try
End Function

Js脚本:

$('#btnSave').click(function () {
  var char = $(this).text();

 var SendData = {};
  $.ajax({
      type: "POST",
      url: "TEST.aspx/GetReport",
      data: JSON.stringify(SendData),
      data: "{ 'Data': '" + char + "'}",
      contentType: "application/json; charset=utf-8",
      dataType: "json",
      success: function (data) {
          $('#lbl_test').text(data.d);
      },
      error: function (data, success, error) {
          alert("Error:" + error);
      }
  });
 });

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM