账号密码登录
微信安全登录
微信扫描二维码登录

登录后绑定QQ、微信即可实现信息互通

手机验证码登录
找回密码返回
邮箱找回 手机找回
注册账号返回
其他登录方式
分享
  • 收藏
    X
    前端向后端发送post请求,如何将发送的json数据序列化?
    • 昵称过于强大无法显示2017-12-06 00:00
    • 10
    23
    0

    代码:

     $.ajax({
                        type        : 'post',
                        url         : 'test.php',
                        data        : {
                                            'Data' : {
                                                'Mark' : 4,
                                                'PhoneNumber' : 12312312312
                                            }
                                       },
                        success     : function(res){
                            // 请求成功
                           console.log(res);
                        }         
                   });

    但是 出现如下情况

     
     Form Data
       Data%5BMark%5D=4&Data%5BPhoneNumber%5D=12312312312
       后端拿到数据没法处理数据了,
       为什么会这样呢?怎么让发的数据变为{"Data":{"Mark":4,"PhoneNumber":"12312312312"}}呢?
    0
    打赏
    收藏
    点击回答
    您的回答被采纳后将获得:提问者悬赏的 10 元积分
        全部回答
    • 0
    • ︶征服 普通会员 1楼

      在前端向后端发送POST请求时,我们通常会将数据作为请求体发送。为了序列化JSON数据,我们可以使用JavaScript的JSON.stringify()方法。这个方法可以将JavaScript对象或数组转换为一个JSON字符串。

      以下是一个简单的示例:

      ```javascript var data = { "name": "John", "age": 30 }; var jsonStr = JSON.stringify(data);

      // 向后端发送POST请求 var xhr = new XMLHttpRequest(); xhr.open('POST', '/api/data', true); xhr.setRequestHeader('Content-Type', 'application/json'); xhr.send(jsonStr); ```

      在这个示例中,我们首先定义了一个包含JSON数据的对象。然后,我们使用JSON.stringify()方法将这个对象转换为JSON字符串。最后,我们使用XMLHttpRequest对象向后端发送POST请求,其中Content-Type属性设置为'application/json',因为我们正在发送的是JSON数据。

      注意,这个示例假设你的后端API可以接受JSON数据。如果你的API无法接受JSON数据,你可能需要修改你的JSON.stringify()方法以适应你的API的需要。

    更多回答
    扫一扫访问手机版
    • 回到顶部
    • 回到顶部