为啥 'axios' 和 $http (vue-resource) 对于 json 查询字符串的行为不同?

Posted

技术标签:

【中文标题】为啥 \'axios\' 和 $http (vue-resource) 对于 json 查询字符串的行为不同?【英文标题】:Why 'axios' and $http (vue-resource) behave differently for json query string?为什么 'axios' 和 $http (vue-resource) 对于 json 查询字符串的行为不同? 【发布时间】:2018-02-24 12:42:12 【问题描述】:

我正在开发一个vue 应用程序并从我使用vue-resource 的服务器获取数据

我使用 vue-resource 的代码是

this.$http.get('api/url', 
     params: 
         authData: authData,
         otherData: otherData
     
)

这里的authdata是json字符串,类似于"userName":"User+name","id":"userid",....

现在由于某些原因我不得不搬到axios 所以我将我的代码更改为

axios.get('api/url', 
     params: 
         authData: authData,
         otherData: otherData
     
)

在这两种情况下,数据都是相同的,但是当我看到网络调用时。我得到了不同的结果。

第一种情况网络调用中的查询字符串是

authData[userName]: 'User+name'
authData[id]    : 'userid'
otherData: 'otherData'

第二种情况网络调用中的查询字符串是

authData: "userName":"User+name","id":"userid"....
otherData: 'otherData'

现在我的问题是为什么会发生这种情况以及如何在axios 中实现第一种格式。我不想手动将 json 字符串转换为数组

【问题讨论】:

【参考方案1】:

这是因为 Axios 将 javascript 对象序列化为 JSON。要以 application/x-www-form-urlencoded 格式序列化,您需要使用techniques described in the Axios documentation 之一。

我认为qs 对你来说是一个不错的解决方案:

// Use object shorthand notation if it's supported in your environment
axios.post('/foo', qs.stringify( authData, otherData ));

【讨论】:

【参考方案2】:

Axios 在发送参数时默认为 application/json,而 vue-resource 在您的情况下以 application/x-www-form-urlencoded 格式发送参数。

您可以使用我从 gist 获得的这个函数,并使用它将您的对象转换为 URL 编码的字符串。

function JSON_to_URLEncoded(element, key, list)
  var list = list || [];
  if (typeof(element) == 'object')
    for (var idx in element)
      JSON_to_URLEncoded(element[idx],key?key+'['+idx+']':idx,list);
   else 
    list.push(key+'='+encodeURIComponent(element));
  
  return list.join('&');

你可以这样使用它:

var params = JSON_to_URLEncoded(auth: username: 'someUser', id: 'someID', other: 'other')
console.log(params)

axios.get('/url?' + params, 
  headers: 
    contentType: 'x-www-form-urlencoded'
  
)

【讨论】:

以上是关于为啥 'axios' 和 $http (vue-resource) 对于 json 查询字符串的行为不同?的主要内容,如果未能解决你的问题,请参考以下文章

为啥 axios get 方法请求发送两次?

为啥我的 Axios 实例没有在捕获的错误中返回响应?

Javascript - 无法发布数据(使用 axios),而它在邮递员中工作。为啥?

为啥axios请求接口会发起两次请求

(Vue) Axios 设置数据不适用于 2 个属性。我无法解释为啥

需要帮助 为啥 TailwindCSS 不起作用?如果通过 axios 打开模态