码迷,mamicode.com
首页 > 移动开发 > 详细

axios请求JSON问题详解

时间:2018-01-13 00:13:33      阅读:1010      评论:0      收藏:0      [点我收藏+]

标签:url   tps   lock   href   axios   catch   str   格式   load   

  • 当参数是JSON对象时,默认的Content-Type是application/json。

    axios.post(‘/user‘, {
        firstName: ‘Fred‘,
        lastName: ‘Flintstone‘
      })
      .then(function (response) {
        console.log(response);
      })
      .catch(function (error) {
        console.log(error);
      });

    此时传递的参数是Request Payload格式{firstName:"Fred",lastName:"Flintstone"}

    如果出现No ‘Access-Control-Allow-Origin‘ header is present on the requested resource的错误,则是跨域问题。本人喜欢直接配置服务器来解决跨域:例如Nginx配置:Nginx配置跨域请求

  • 当参数是JSON字符串时,默认的Content-Type是application/x-www-form-urlencoded。

    axios.post(‘/user‘, JSON.stringify({
        firstName: ‘Fred‘,
        lastName: ‘Flintstone‘
      }))
      .then(function (response) {
        console.log(response);
      })
      .catch(function (error) {
        console.log(error);
      });

    此时传递的参数是Form Data格式key : value

    {"firstName":"Fred","lastName":"Flintstone"}:

    如上。其实这是一个无效的数据,key为{"firstName":"Fred","lastName":"Flintstone"},value为空。

  • 要想使用application/x-www-form-urlencoded格式,需要进行数据转换,虽然有两种方式URLSearchParamsqs两种方式。我更喜欢使用qs库的方式,代码如下:
    axios.interceptors.request.use((req) => {
        if (req.method === ‘post‘) {
         req.data = qs.stringify(req.data);
        }
        return req;
    }, (error) => Promise.reject(error));

    之后使用axios的时候,只需要传递json对象就可以:

    axios.post(‘/user‘, {
        firstName: ‘Fred‘,
        lastName: ‘Flintstone‘
      })
      .then(function (response) {
        console.log(response);
      })
      .catch(function (error) {
        console.log(error);
      });
  • axios请求JSON问题详解

    标签:url   tps   lock   href   axios   catch   str   格式   load   

    原文地址:http://blog.51cto.com/13523664/2060434

    (0)
    (0)
       
    举报
    评论 一句话评论(0
    登录后才能评论!
    © 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
    迷上了代码!