前端传参如果参数过多你还会拼接在URL上嘛?

当然除了 '+' 拼接你也可以用模版字符串的方式,相对来说可能要好一些,但是如果字段太多的话,还是不太方便,所以这里介绍一种其他的方式,比如qs

qs是npm仓库所管理的包,可以通过npm install qs安装,因此我们可以直接通过require('qs')引用得到,qs.stringify()作用是将对象或者数组序列化成URL的格式。那么这句话是什么意思呢?

我们先来看一下官方的用法

Usage

js 复制代码
var qs = require('qs');
var assert = require('assert');

var obj = qs.parse('a=c');
assert.deepEqual(obj, { a: 'c' });

var str = qs.stringify(obj);
assert.equal(str, 'a=c');

非常简单,直接引入然后通过qs.stringify() ,qs.parse() 就可以了。

下面我们举两个例子:

  • 对象序列化
vbnet 复制代码
let obj = {
methods: 'query_num'
id: 1,
name: 'Lisa'
}
qs.stringify(obj)
//   methods=query_stu&id=1&name=chenchen    这就是我们的传到服务器的url
  • 数组序列化
css 复制代码
let arr = [1,3]
qs.stringify({a:arr})
// 'arr[0]=1&arr[1]=3'

这种格式可以进行转为序列化,但是url中会带有数组的下标a[0]、a[1],这并不是我们一般的处理办法。常用方法如下:

php 复制代码
// 常用并推荐使用
let arr = [1,3]
qs.stringify({a:arr},{indices:false});
// 'arr=1&arr=3' 这个格式,是比较常用的格式

其中:indices:false,去除默认处理的方式。如果不写这个的话,则默认是第一种处理的方式(带下标)。

qs.parse()则就是反过来的,将我们通过qs.stringify()序列化的对象或者数组转回去。

bash 复制代码
let url = 'id=1&name=chenchen'
qs.parse(url)
// {id:1,name:chenchen}  

接下来看一个实例:

php 复制代码
// 根据业务id查询业务费用列表
export function commonBuzCostPage(params) {
  return request({
    url: `/departmentCost/commonBuzCostPage`,
    method: 'get',
    params,
    paramsSerializer: params => {
      return qs.stringify(params, {
        indices: false
      })
    }
  })
}
javascript 复制代码
fetch(`${apiurl}/projiects?${qs.stringify(param)}`) 
.then(async response =>{
    if (response.ok){
        setList(await response.json())
        }
    })
相关推荐
kyriewen11 分钟前
老板逼我上AI,我偷偷在浏览器里跑LLaMA,省下20万API费
前端·react.js·llm
Beginner x_u21 分钟前
前端八股整理(手写 02)|数组转树、数组扁平化、随机打乱一个数组
前端·数组·数组转树·数组扁平化
KaMeidebaby25 分钟前
卡梅德生物技术快报|禽类成纤维细胞 FISH 实验:鸟类性别染色体基因定位技术实现与数据验证
前端·数据库·其他·百度·新浪微博
天若有情67337 分钟前
前端高阶性能优化:跳出传统懒加载与预加载,基于用户行为做轻量预判加载
前端·性能优化
小小小小宇41 分钟前
前端转后端:SQL 是什么
前端
张元清2 小时前
React Observer Hooks:7 种监听 DOM 而不写样板代码的方式
前端·javascript·面试
广州华水科技2 小时前
单北斗GNSS变形监测是什么?主要有怎样的应用与优势?
前端
卷帘依旧2 小时前
【未完待续】React高频面试题
前端
m0_738120722 小时前
ctfshow靶场SSRF部分——基础绕过到协议攻击解题思路与技巧(一)
服务器·前端·网络·安全·php
counterxing2 小时前
AI Agent 做长任务,问题到底 出在哪?
前端·后端·ai编程