• axios中post请求 json 和 application/x-www-form-urlencoded


    前端向后端传输数据时,如果是get传输,直接传在url后;如果是post传输,则在请求体body中传输。

    body中的数据格式又有两种,一种是  json  数据格式,另一种是 字符串。具体要用哪种格式取决于后端入参的格式。

    如果后端接收json数据类型,post 的 headers 需要设置 { ‘content-type’: ’application/json’ },传给后端的数据就形如  { ‘name’:’edward’, ‘age’:’25’ } 

    如果后端接收的是(表单)字符串类型,post 的 headers 需设置  { ‘content-type’: ’application/x-www-form-urlencoded’ },

    ,传输给后端的数据就形如   ‘name=edward&age=25’  

       qs   

    qs.stringfy() 将对象序列化成URL的形式

    axios默认数据格式为json,所以:

    1.当后端需要接收json格式的数据时,post请求头不需要设置请求头,数据格式也不需要我们去转换(若数据已经是json);

    2.当后端需要接收字符串格式的数据时,我们需要给post请求头设置{ ‘content-type’: ’application/x-www-form-urlencoded’ },

       这个时候如果我们传的入参是一个 js 对象,这时候我们就需要用 qs 转换数据格式,qs具体用法如下

     安装模块:npm  i  qs  -S

    import qs from 'qs';
    const data = { name:'edward' , age:'25'};  // 我们传的是 js 对象
    const options = {
      method: 'POST',
      headers: { 'content-type': 'application/x-www-form-urlencoded' },
      data: qs.stringify(data),   // 用 qs 将js对象转换为字符串 'name=edward&age=25'
      url: 'http://www.edward.com'
    }; 
    axios(options);

     我们也可以在封装axios的时候,给它全局设置qs 

    axios.defaults.baseURL = 'https://api.example.com';
    axios.defaults.headers.common['Authorization'] = AUTH_TOKEN;
    axios.defaults.headers.post['Content-Type'] = 'application/x-www-form-urlencoded';

    【区分】: JSON.stringfy()  和 qs.stringfy() 

      let  data = { name: 'edward', age: '25' }

      前者:JSON.stringfy(data)  //  ”{ 'name' : 'edward' , 'age' : '25' }”

      后者:qs.stringfy(data)  // 'name=edward&age=25'

    【区分】:jQuery 中 $.ajax 的post请求  VS   axios的post 请求的 content-type 默认值

      前者:"application/x-www-form-urlencoded"

      后者:"application/json"

    $.ajax({
       type: 'POST',
       contentType: 'application/json;charset=utf-8', // 发送的数据类型
       dataType: 'json',   // 接收的数据类型
       url: 'http://www.edward.com',
       data: JSON.stringfy(formData),
       success: function (res) {
          console.log(res.data) 
       }
    }) 

    contentType: 告诉服务器,我要发什么类型的数据

    dataType:告诉服务器,我要想什么类型的数据,如果没有指定,那么会自动推断是返回 XML,还是JSON,还是script,还是String。

    注意 :$.ajax() post发送到服务器的数据。将自动转换为请求字符串格式

    如果为对象,如 { name: 'edward', age: '25' },jQuery 将自动转化为 'name=edward&age=25'

    如果为数组,jQuery 将自动为不同值对应同一个名称。如 {foo:["bar1", "bar2"]} 转换为 '&foo=bar1&foo=bar2'。

    作者:牧羊狼

    出处:https://www.cnblogs.com/edwardwzw/

    本文版权归作者和博客园共有,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文连接,否则保留追究法律责任的权利,谢谢您的配合。 Freedom is not let you do whatever you wanna but teach you not to do the things that you donnot wanna do.

  • 相关阅读:
    JSON以及Java转换JSON的方法(前后端经常使用处理方法)
    让cocos2dx支持并通过arm64 编译
    matlab7安装后的常见问题
    Open SSH原理
    Bringing up interface eth0: Device eth0 does not seem to be present, delaying initialization
    12C -- 配置EM Express的端口
    ORA-16179: incremental changes to "log_archive_dest_1" not allowed with SPFILE
    ORA-16019: cannot use LOG_ARCHIVE_DEST_1 with LOG_ARCHIVE_DEST or LOG_ARCHIVE_DUPLEX_DEST
    11g新特性-SQL Plan Management
    11g新特性-自动sql调优(Automatic SQL Tuning)
  • 原文地址:https://www.cnblogs.com/edwardwzw/p/11694903.html
Copyright © 2020-2023  润新知