vue3中处理不同数据结构JSON的实现

 更新时间:2023年06月19日 11:13:58   作者:故里2130  
本文主要介绍了vue3中处理不同数据结构JSON的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧

有时候,后端返回的JSON数据格式,是前端不需要的格式类型,这时,要么让后端修改,你要什么格式,那么让后端大哥哥给你返回什么格式。但是有时候不尽人意,后端大哥哥让你自己转换,此时就甩给前端了,只能在前端自己处理了。

1.对后端数据的字段值/字段进行操作

后端的JSON格式:

//后端返回的数据格式
		var data = ref([{
				id: '00111322',
				name: 'zs01',
				age: 18
			},
			{
				id: '00035565644',
				name: 'ls02',
				age: 20
			}
		])

1.对字段的值进行更改

//返回的格式
		var data1 = data.value.map(res => {
			return {
				...res, //...使用es6语法,表示每一个对象,这里指的就是 {id: '00111322',name: 'zs01',age: 18}
				id: Number(res.id), //把字符串转换数字类型
				age: res.age + 1, //给每一个人加一岁
				name: res.name.substring(0, 2) //把name的值截取2位
			}
		})
		console.log(...data1) //...表示返回每一个元素

效果 

2.对字段进行操作

//返回的格式
		var data1 = data.value.map(res => {
			return {
				...res, //...使用es6语法,表示每一个对象,这里指的就是 {id: '00111322',name: 'zs01',age: 18}
				id: Number(res.id), //把字符串转换数字类型
				age: res.age + 1, //给每一个人加一岁
				name1: res.name.substring(0, 2), //把name的值截取2位,并且需要name1字段
				mark:res.id+res.name
			}
		})
		console.log(...data1) //...表示返回每一个元素

效果 

2.处理多层级的数据结构

后端的JSON格式:

//后端返回的数据格式
		var data = ref([{
			title: '一号楼',
			key: '100',
			children: [{
				title: '一单元',
				key: '110',
				children: [{
						title: '房间1',
						key: '111'
					},
					{
						title: '房间2',
						key: '112'
					}
				]
			}]
		}])

1.修改字段操作

//把title和key,分别改成id和name,一一对应起来,返回的格式 ,使用递归的方式
		function formatData(data1) {
			data1.forEach(res => {
				res.id = res.key;
				res.name = res.title;
				delete res.key;
				delete res.title;
				if (res.children) {
					formatData(res.children)
				}
			})
		}
		formatData(data.value) //调用
		console.log(...data.value) //...表示返回每一个元素
		console.log(JSON.stringify(data.value)) //返回字符串

效果

2.修改字段的值操作

//在最后一个字段title中,把前面的数据加上
		function formatData(data1, text) {
			data1.forEach(res => {
				if (!res.children) {
					res.title = text + res.title
				}
				if (res.children) {
					text += res.title;
					formatData(res.children, text)
				}
			})
		}
		formatData(data.value, '') //调用
		console.log(...data.value) //...表示返回每一个元素
		console.log(JSON.stringify(data.value)) //返回字符串

效果

3.对JSON的字段进行排序 

后端JSON数据格式:

//后端返回的数据格式
		var data = ref([{
			title: '一号楼',
			key: '100',
			children: [{
				title: '一单元',
				key: '110',
				children: [{
						title: '房间1',
						key: '111'
					},
					{
						title: '房间2',
						key: '112'
					}
				]
			}]
		}, {
			title: '二号楼',
			key: '200',
			children: [{
				title: '二单元',
				key: '210',
				children: [{
						title: '房间1',
						key: '211'
					},
					{
						title: '房间2',
						key: '212'
					}
				]
			}]
		}])

根据key的值排序

//根据根据key的值排序
		const compare = p => (m, n) => n[p] - m[p]; //简写排序,可以参考JavaScript中sort() 方法   
		//m[p] - n[p]升序    n[p] - m[p] 降序
		function formatData(data1, sortField) { //key:需要排序的字段
			data1.sort(compare(sortField));
			data1.forEach(res => {
				if (!res.children) {
					return;
				} else {
					formatData(res.children, sortField);
				}
			});
		}
		formatData(data.value, 'key') //调用,根据key的值排序
		console.log(...data.value) //...表示返回每一个元素
		console.log(JSON.stringify(data.value)) //返回字符串

效果,降序排列

4.实际案例

1.在使用uCharts时,经常需要进行数据转换

2.把res转成res1格式,因为res1是需要的

3.定义 res

let res = ref(
		[{
				"name": "的方式是大多数",
				"value": 6
			},
			{
				"name": "yqwuwiyvui",
				"value": 3
			},
			{
				"name": "sdsfsdf",
				"value": 2
			},
			{
				"name": "wewerw",
				"value": 6
			}
		]
	)

4.定义res1和res1s,因为res1s是res1中series的值

let res1 = ref({
		categories: [],
		series: []
	})
	let res1s = ref({
		name: "",
		data: []
	})

5.转换

res.value.forEach((va) => {
			res1.value.categories.push(va.name)
			res1s.value.data.push(va.value)
		})
		res1s.value.name = "目标值"
		res1.value.series.push(res1s.value)
		chartData.value = res1.value

6.效果

上面的方式可以实现,没有问题,应该还有别的方式也行。

到此这篇关于vue3中处理不同数据结构JSON的实现的文章就介绍到这了,更多相关vue3处理JSON内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • vue+vite+diff.js使用小结

    vue+vite+diff.js使用小结

    本文主要介绍了vue+vite+diff.js使用小结,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2023-12-12
  • vue子组件设计provide和inject理解使用

    vue子组件设计provide和inject理解使用

    这篇文章主要为大家介绍了vue子组件设计provide和inject理解及使用示例详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2023-08-08
  • vue如何使用element-ui 实现自定义分页

    vue如何使用element-ui 实现自定义分页

    这篇文章主要介绍了vue如何使用element-ui 实现自定义分页,可以通过插槽实现自定义的分页,本文通过实例图文相结合给大家介绍的非常详细,感兴趣的朋友一起看看吧
    2024-07-07
  • 解决vue props 拿不到值的问题

    解决vue props 拿不到值的问题

    今天小编就为大家分享一篇解决vue props 拿不到值的问题,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2018-09-09
  • Vue中常用rules校验规则(实例代码)

    Vue中常用rules校验规则(实例代码)

    这篇文章主要介绍了Vue中常用rules校验规则,本文通过实例代码个大家介绍了一些校验方法,需要的朋友可以参考下
    2019-11-11
  • select的change方法传递多个参数的方法详解

    select的change方法传递多个参数的方法详解

    element-ui中的select,checkbox等组件的change方法的回调函数只有当前选择的val,如果想再传入自定义参数怎么办,本文给大家分享select的change方法如何传递多个参数,感兴趣的朋友一起看看吧
    2024-02-02
  • vue项目安装scss常见报错处理方式

    vue项目安装scss常见报错处理方式

    这篇文章主要介绍了vue项目安装scss常见报错处理方式,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-09-09
  • vue封装Animate.css动画库的使用方式

    vue封装Animate.css动画库的使用方式

    这篇文章主要介绍了vue封装Animate.css动画库的使用方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2024-04-04
  • el-tree设置选中高亮/焦点高亮、选中节点加深背景及更改字体颜色等的方法

    el-tree设置选中高亮/焦点高亮、选中节点加深背景及更改字体颜色等的方法

    el-tree默认有较浅的背景色,这里业务需要,选中节点的字体高亮,更改颜色,下面这篇文章主要给大家介绍了关于el-tree选中高亮/焦点高亮、选中节点加深背景及更改字体颜色等的设置方法,需要的朋友可以参考下
    2022-12-12
  • Vue实现带参数的自定义指令示例

    Vue实现带参数的自定义指令示例

    这篇文章主要为大家介绍了Vue实现带参数的自定义指令示例详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2023-01-01

最新评论