位置: IT常识 - 正文

前端 - get请求传递数组(前端get请求传数组)

编辑:rootadmin
前端 - get请求传递数组

推荐整理分享前端 - get请求传递数组(前端get请求传数组),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:前端get请求传递json参数,前端get请求传递json参数,前端get请求传数组,前端get请求传数组,前端get请求传参字符串,前端get请求传递数组,前端get请求传入url链接 后端接收不全,前端get请求传入url链接 后端接收不全,内容如对您有帮助,希望把文章链接给更多的朋友!

感谢后端让我的知识点 + 1

一、数组请求方式

get 请求有以下几种方式来传递数组:

GET http://localhost:8080/users?roleIds=1&roleIds=2GET http://localhost:8080/users?roleIds[0]=1&roleIds[1]=2GET http://localhost:8080/users?roleIds[]=1&roleIds[]=2GET http://localhost:8080/users?roleIds=1,2二、解决方案自己解决let a = ["b", "c", "d"];let str = "";for(var index in a){ str+='a='+a[index]+'&'}// str: a=b&a=c&a=d借助qs插件

qs.stringify({ a: [“b”, “c”, “d”] }); // a[0]=b&a[1]=c&a[2]=d

前端 - get请求传递数组(前端get请求传数组)

qs.stringify({ a: [“b”, “c”, “d”] }, { indices: false }); // a=b&a=c&a=d

qs 还可以通过arrayFormat 选项进行格式化输出:

qs.stringify({ a: [“b”, “c”] }, { arrayFormat: ‘indices’ }) // a[0]=b&a[1]=c qs.stringify({ a: [“b”, “c”] }, { arrayFormat: ‘brackets’ }) // a[]=b&a[]=c qs.stringify({ a: [“b”, “c”] }, { arrayFormat: ‘repeat’ }) // a=b&a=c qs.stringify({ a: [“b”, “c”] }, { arrayFormat: ‘comma’ }) // a=b,c

三、axios 配置

axios中有一个专门对数据进行序列化的配置属性paramsSerializer

{ url: '/user', method: 'get', // default baseURL: 'https://some-domain.com/api/', // `paramsSerializer` 是一个负责 `params` 序列化的函数 // (e.g. https://www.npmjs.com/package/qs, http://api.jquery.com/jquery.param/) paramsSerializer: function(params) { return qs.stringify(params,{arrayFormat: 'brackets'}) },}

在axios请求拦截器中对参数进行序列化配置

axios.interceptors.request.use(async (config) => {//只针对get方式进行序列化 if (config.method === 'get') { config.paramsSerializer = function(params) { return qs.stringify(params, { arrayFormat: 'repeat' }) } }}四、参数转译

需要注意的是,如果请求参数中带有中括号[],[]在url中属于功能性字符,前端需要使用decodeURIComponent()函数转义,否则会出现400 Bad Request错误。

qs.stringify({ a: [‘b’, ‘c’, ‘d’] }); // a%5B0%5D=b&a%5B1%5D=c&a%5B2%5D=ddecodeURIComponent(qs.stringify({ a: ["b", "c", "d"] }) // a[0]=b&a[1]=c&a[2]=d

参考链接 axios中文文档 vue中get请求如何传递数组参数

本文链接地址:https://www.jiuchutong.com/zhishi/297565.html 转载请保留说明!

上一篇:解决雪花算法生成的ID传输前端后精度丢失(雪花算法workid)

下一篇:Vue.js面试题(21级就业版)(vue面试题简书)

  • 税收要素的灵魂
  • 母公司和子公司可以一起投标吗
  • 研发设备可以一次性扣除吗
  • 怎么根据实发工资算应发工资
  • 合同成本在哪个科目列支
  • 核定征收可以无发票做账吗
  • 挖掘机要交多少个人所得税
  • 水泥销售成本怎么算
  • 以前年度损益调整影响哪个科目
  • 无形资产应当按照公允价值进行初始计量吗
  • 零余额账户银行余额调节表
  • 没有签字的支出凭证怎么处理?
  • 个人所得税税费种认定功能在哪里
  • 公司给员工的商业保险
  • 三证合一办完后的流程
  • 延期付款利息到底有没有税务风险
  • 报税没有印花税怎么处理
  • 土地契税及印花税缴纳规定
  • 工地伙食标准 费用
  • 承租人交付房屋标准
  • 进货价加多少卖不亏增值税
  • 诉讼费做账科目
  • 结算银行贷款利息用什么凭证
  • 工程结算收入以前年度多结转收入怎么处理?
  • 小企业执行新会计准则吗
  • 不缴或少缴应纳税款的行为属于
  • 固定资产转在建工程提折旧吗
  • 测速网在线测速
  • 发票金额大于报销金额违法吗
  • win11 桌面右键
  • 资产负债表存货包括哪些科目
  • 交际应酬性支出是什么
  • 股本减少的账务怎么处理
  • 收到的担保费如何记账
  • spring boot 接受参数
  • yii框架运行原理
  • 当月已验旧的发票怎么开
  • 关于php通用返回的问题
  • 固定资产评估如何做
  • 自动驾驶感知算法
  • 销售费用的主要类型有哪些
  • Python中tkinter的 Variable类
  • 预收账款属于什么科目
  • 一般纳税人购进免税农产品如何抵扣进项税额
  • 其他综合收益要结转到本年利润吗
  • 冲减多计提的工资怎么做账
  • 帝国cms商城教程
  • window10解压文件
  • 数据库帮助文档
  • mysql复制表结构及数据
  • ubuntu 14.04 安装分区教程
  • 收支平衡表excel怎么做
  • 专项扣除三险一金是哪三险
  • 劳务派遣合法吗
  • 小额贷款公司如何做账
  • 专项应付款转资本公积需要缴纳所得税
  • 收到生育津贴会计分离
  • 第三方代销什么意思
  • 过期产品进项税用转出吗
  • 固定资产可资本化的后续支出
  • 投资性房地产在建
  • 本年利润月末怎么处理
  • 开销项负数的流程
  • 跨年材料票可以入账吗
  • 企业会计制度怎么写
  • 现金日记账怎么划线
  • sql server设置
  • sql不重复计数函数
  • mysq删除数据库
  • Tech Ed 2008:HPC Server 2008讲解
  • win8怎么下载qq
  • windows7出现错误恢复怎么办
  • win7 64位打开软件时显示丢失wpcap.dll的三种解决办法
  • 搭建oj
  • 批处理文件是可执行文件吗
  • jquery怎么打开
  • 四川国税局普通发票查询?
  • 国家电子税务局江苏省电子税务局
  • 重庆国税电子税务局
  • 上饶国资委领导班子成员名单
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设