qs库更好的处理url参数


qs.js - 更好的处理url参数

第一次接触qs这个库,是在使用axios时,用于给post方法编码,在使用过程中,接触到了一些不同的用法,写在这里分享一下。

qs.parse

  1. qs.parse 方法可以把一段格式化的字符串转换为对象格式,比如
    let url = 'http://item.taobao.com/item.htm?a=1&b=2&c=&d=xxx&e';
    let data = qs.parse(url.split('?')[1]);
    // data的结果是
    {
     a: 1, 
     b: 2, 
     c: '', 
     d: xxx, 
     e: ''
    }

qs.stringify

基本用法
2. qs.stringify 则和 qs.parse 相反,是把一个参数对象格式化为一个字符串。

let params = { c: 'b', a: 'd' };
qs.stringify(params)

// 结果是
'c=b&a=d'
  1. 排序
    甚至可以对格式化后的参数进行排序:
    qs.stringify(params, (a,b) => a.localeCompare(b))
    

// 结果是
‘a=b&c=d’


指定数组编码格式
```js
let params = [1, 2, 3];

// indices(默认)
qs.stringify({a: params}, {
    arrayFormat: 'indices'
})
// 结果是
'a[0]=1&a[1]=2&a[2]=3'

// brackets 
qs.stringify({a: params}, {
    arrayFormat: 'brackets'
})
// 结果是
'a[]=1&a[]=2&a[]=3'

// repeat
qs.stringify({a: params}, {
    arrayFormat: 'repeat'
})
// 结果是
'a=1&a=2&a=3'

处理json格式的参数
在默认情况下,json格式的参数会用 [] 方式编码,

let json = { a: { b: { c: 'd', e: 'f' } } };

qs.stringify(json);
//结果 'a[b][c]=d&a[b][e]=f'

但是某些服务端框架,并不能很好的处理这种格式,所以需要转为下面的格式

qs.stringify(json, {allowDots: true});
//结果 'a.b.c=d&a.b.e=f'

文章转自 https://www.cnblogs.com/small-coder/p/9115972.html


文章作者: Mr. Zhan
版权声明: 本博客所有文章除特別声明外,均采用 CC BY 4.0 许可协议。转载请注明来源 Mr. Zhan !
 上一篇
porimse封装wx.request porimse封装wx.request
porimse封装wx.requestconst request = ({url, method = 'GET', data, header}) => { let headers = { // 默认值 'content-typ
2020-05-05 Mr. Zhan
下一篇 
防抖节流函数 防抖节流函数
防抖节流函数一、防抖函数(debounce)防抖函数:一个需要频繁触发的函数,在规定的时间内,只让最后一次生效,前面的不生效。常见例子:搜索框中输入关键字自动发送网络请求。 function debounce(fn,delay){
2020-04-21 Mr. Zhan
  目录