浅谈vue中get请求解决传输数据是数组格式的问题


Posted in Javascript onAugust 03, 2020

qs的stringify接收2个参数,第一个参数是需要序列化的对象,第二个参数是转化格式,一般默认格式是给出明确的索引,如:arr[0]=1&arr[1]=2

//indices是index的复数格式,因此indices是索引的意思
//bracket是括号的意思,因此arrayFormat:'brackets'代表数组下标为空[]

qs.stringify({ arr: [1,2,3] }, { indices: false }) //arr=1&arr=2&arr=3
qs.stringify({ arr: [1,2,3] }, { arrayFormat: 'indices' }) //arr[0]=1&arr[1]=2&arr[2]=3
qs.stringify({ arr: [1,2,3] }, { arrayFormat: 'brackets' }) //arr[]=1&arr[]=2&arr[]=3
qs.stringify({ arr: [1,2,3] }, { arrayFormat: 'repeat' }) //arr=1&arr=2&arr=3

qs的parse()使用

如果接口需要获取get请求接口的请求数据,可以使用parse(),将拼接在地址的参数数据转换为对象

let url = "111.111.3.203:8080/getList?id=1&name=huahua&arr=a&arr=b"
let splitObj = url.split('?')[1]
qs.parse(splitObj )  //{ id: '1', name: 'huahua', arr: ['a','b'] }

qs.stringify和JSON.stringify的区别

let obj = { a: 1, b: 2 }
qs.stringify(obj)  //a=1&b=2
JSON.stringify(obj) // "{'a': 1, 'b': 2}"

qs解决数组参数问题

安装axios,qs

npm install qs

npm install axios -S

在main.js中引入qs

import Vue from 'vue'
import qs from 'qs'
import axios from 'axios'
Vue.prototype.$qs = qs;  //qs全局挂载在vue实例上
Vue.prototype.$http = axios; //axios全局挂载在vue实例上

在组件中使用

get请求的请求参数是将数据放在config的params中,实际是通过“&”拼接在url上

如果请求参数是数组arr=[1,2,3],get请求不对数组做任何处理,则传递给后端的接口是

"url地址?arr[]=1&arr[]=2&arr[]=3",接口会报错,因为识别不了“[]”这个符号

需要对数组进行修改,需要通过qs的stringify()方法将数组序列化,则传递给后端的接口是 “url地址?arr=1&arr=2&arr=3”,接口不会报错

this.arr = [1,2,3]
//写法一,直接使用qs的stringify()
this.$http.get('url地址', {
 params: {
 arr: this.$qs.stringify(this.arr)  //数组拼接在url地址 url地址?arr=1&arr=2&arr=3
 }
}).then(() => {
}) 

//写法二 ,使用axios提供的paramsSerializer序列化函数
this.$http.get('url地址', {
 params: {
 arr: this.arr  //数组拼接在url地址 url地址?arr=1&arr=2&arr=3
 },
 paramsSerializer: (params) => {
 return this.$qs.stringify(params) 
 }
}).then(() => {
})

以上这篇浅谈vue中get请求解决传输数据是数组格式的问题就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
jQuery 动画弹出窗体支持多种展现方式
Apr 29 Javascript
jQuery编写widget的一些技巧分享
Oct 28 Javascript
jquery.bgiframe.js在IE9下提示INVALID_CHARACTER_ERR错误
Jan 11 Javascript
jsp网页搜索结果中实现选中一行使其高亮
Feb 17 Javascript
node.js中的http.response.end方法使用说明
Dec 14 Javascript
js实现分割上传大文件
Mar 09 Javascript
JS面向对象的程序设计相关知识小结
May 26 Javascript
微信小程序用户位置权限的获取方法(拒绝后提醒)
Nov 15 Javascript
Vue和React组件之间的传值方式详解
Jan 31 Javascript
vue v-for循环重复数据无法添加问题解决方法【加track-by='索引'】
Mar 15 Javascript
layui.use模块外部使用其内部定义的js封装函数方法
Sep 16 Javascript
vue+canvas实现拼图小游戏
Sep 18 Javascript
VUE使用axios调用后台API接口的方法
Aug 03 #Javascript
vue cli3.0打包上线静态资源找不到路径的解决操作
Aug 03 #Javascript
js数组中去除重复值的几种方法
Aug 03 #Javascript
Vue打包部署到Nginx时,css样式不生效的解决方式
Aug 03 #Javascript
javascript运行机制之执行顺序理解
Aug 03 #Javascript
解决vue+elementui项目打包后样式变化问题
Aug 03 #Javascript
vue实现PC端分辨率适配操作
Aug 03 #Javascript
You might like
PHP中PDO基础教程 入门级
2011/09/04 PHP
php使HTML标签自动补全闭合函数代码
2012/10/04 PHP
Jquery操作js数组及对象示例代码
2014/05/11 Javascript
javascript 数组操作详解
2015/01/29 Javascript
微信小程序 获取相册照片实例详解
2016/11/16 Javascript
JavaScript中关于iframe滚动条的去除和保留
2016/11/17 Javascript
简单实现Vue的observer和watcher
2016/12/21 Javascript
微信小程序倒计时功能实现代码
2017/11/09 Javascript
vue项目在安卓低版本机显示空白的原因分析(两种)
2018/09/04 Javascript
详解vue项目中调用百度地图API使用方法
2019/04/25 Javascript
Vue实现导航栏点击当前标签变色功能
2020/08/19 Javascript
基于VSCode调试网页JavaScript代码过程详解
2020/07/20 Javascript
Python 编码处理-str与Unicode的区别
2016/09/06 Python
python正则表达式及使用正则表达式的例子
2018/01/22 Python
Python装饰器用法示例小结
2018/02/11 Python
python:接口间数据传递与调用方法
2018/12/17 Python
python多线程分块读取文件
2019/08/29 Python
详解Python3定时器任务代码
2019/09/23 Python
python 发送json数据操作实例分析
2019/10/15 Python
Python读取excel文件中带公式的值的实现
2020/04/17 Python
Python脚本调试工具安装过程
2021/01/11 Python
关于iframe跨域使用postMessage的实现
2019/10/29 HTML / CSS
泰国汽车、火车和轮渡票预订网站:Bus Online Ticket
2017/09/09 全球购物
办公室主任岗位职责
2013/11/08 职场文书
计算机专业毕业生自荐信
2013/12/31 职场文书
商务英语大学生职业生涯规划书范文
2014/01/01 职场文书
运动会广播稿100字
2014/01/11 职场文书
公司领导班子对照材料
2014/08/18 职场文书
升国旗演讲稿
2014/09/05 职场文书
纺织工程专业推荐信
2014/09/08 职场文书
明确岗位职责
2015/02/14 职场文书
4S店收银员岗位职责
2015/04/07 职场文书
2015学校图书管理员工作总结
2015/05/11 职场文书
2015年环保局工作总结
2015/05/22 职场文书
python如何利用cv2模块读取显示保存图片
2021/06/04 Python
2022年显卡天梯图(6月更新)
2022/06/17 数码科技