分享web开发知识

注册/登录|最近发布|今日推荐

主页 IT知识网页技术软件开发前端开发代码编程运营维护技术分享教程案例
当前位置:首页 > IT知识

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

发布时间:2023-09-06 01:57责任编辑:顾先生关键词:jsurl

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

qs.parse

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

基本用法

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

let params = { c: ‘b‘, a: ‘d‘ };qs.stringify(params)// 结果是‘c=b&a=d‘

排序

甚至可以对格式化后的参数进行排序:

qs.stringify(params, (a,b) => a.localeCompare(b))// 结果是‘a=b&c=d‘

指定数组编码格式

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‘// repeatqs.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‘

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

原文地址:https://www.cnblogs.com/small-coder/p/9115972.html

知识推荐

我的编程学习网——分享web前端后端开发技术知识。 垃圾信息处理邮箱 tousu563@163.com 网站地图
icp备案号 闽ICP备2023006418号-8 不良信息举报平台 互联网安全管理备案 Copyright 2023 www.wodecom.cn All Rights Reserved