javascript - 使用 jQuery 发送 JSON 数据

标签 javascript jquery ajax

为什么下面的代码将数据发送为 City=Moscow&Age=25 而不是 JSON 格式?

var arr = {City:'Moscow', Age:25};
$.ajax(
   {
        url: "Ajax.ashx",
        type: "POST",
        data: arr,
        dataType: 'json',
        async: false,
        success: function(msg) {
            alert(msg);
        }
    }
);

最佳答案

因为您既没有指定请求内容类型,也没有指定正确的 JSON 请求。以下是发送 JSON 请求的正确方法:

var arr = { City: 'Moscow', Age: 25 };
$.ajax({
    url: 'Ajax.ashx',
    type: 'POST',
    data: JSON.stringify(arr),
    contentType: 'application/json; charset=utf-8',
    dataType: 'json',
    async: false,
    success: function(msg) {
        alert(msg);
    }
});

注意事项:

  • 使用 JSON.stringify 方法将 JavaScript 对象转换为现代浏览器内置的原生 JSON 字符串。如果您想支持旧版浏览器,您可能需要包含 json2.js
  • 使用 contentType 属性指定请求内容类型,以便向服务器指示发送 JSON 请求的意图
  • dataType: 'json' 属性用于您期望从服务器获得的响应类型。 jQuery 足够智能,可以从服务器 Content-Type 响应 header 中猜测它。因此,如果您有一个或多或少遵循 HTTP 协议(protocol)并以 Content-Type: application/json 响应您的请求的 Web 服务器,jQuery 会自动将响应解析为 javascript 对象并放入 success 回调,这样您就无需指定 dataType 属性。

注意事项:

  • 您所说的arr不是数组。它是一个具有属性(CityAge)的 JavaScript 对象。数组在 JavaScript 中用 [] 表示。例如 [{ City: 'Moscow', Age: 25 }, { City: 'Paris', Age: 30 }] 是一个包含 2 个对象的数组。

关于javascript - 使用 jQuery 发送 JSON 数据,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/47320980/

相关文章:

Javascript 数字格式化最小/最大小数

javascript - 在 onclick 处理程序中修改目标 url

php - 如何根据复选框更新数据库值? jquery/php/ajax

javascript - d3 饼 : redraw label on path change

javascript - 如何在 JQuery 中完全验证十进制值?

javascript - 如何动态更新数组中另一个对象中的嵌套对象?

javascript - 根据 php 的结果禁用输入

PHP 检查数据库中的用户 ID

javascript - 暂停时暂停音乐淡入/淡出?

javascript - 上传网站时如何在 MVC 页面上结束/停止 JQuery Loader