065:vue中将一维对象数组转换为二维对象数组

这篇具有很好参考价值的文章主要介绍了065:vue中将一维对象数组转换为二维对象数组。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

065:vue中将一维对象数组转换为二维对象数组,# vue2常用示例500+,vue.js,elementui,vue数组转换,一维数组转换为二维数组

第065个

查看专栏目录: VUE ------ element UI

专栏目标

在vue和element UI联合技术栈的操控下,本专栏提供行之有效的源代码示例和信息点介绍,做到灵活运用。

(1)提供vue2的一些基本操作:安装、引用,模板使用,computed,watch,生命周期(beforeCreate,created,beforeMount,mounted, beforeUpdate,updated, beforeDestroy,destroyed,activated,deactivated,errorCaptured,components,)、 $root , $parent , $children , $slots , $refs , props, $emit , eventbus ,provide / inject, Vue.observable, $listeners, $attrs, $nextTick , v-for, v-if, v-else,v-else-if,v-on,v-pre,v-cloak,v-once,v-model, v-html, v-text, keep-alive,slot-scope, filters, v-bind,.stop, .native, directives,mixin,render,国际化,Vue Router等

(2)提供element UI的经典操作:安装,引用,国际化,el-row,el-col,el-button,el-link,el-radio,el-checkbox ,el-input,el-select, el-cascader, el-input-number, el-switch,el-slider, el-time-picker, el-date-picker, el-upload, el-rate, el-color-picker, el-transfer, el-form, el-table, el-tree, el-pagination,el-badge,el-avatar,el-skeleton, el-empty, el-descriptions, el-result, el-statistic, el-alert, v-loading, $message, $alert, $prompt, $confirm , $notify, el-breadcrumb, el-page-header,el-tabs ,el-dropdown,el-steps,el-dialog, el-tooltip, el-popover, el-popconfirm, el-card, el-carousel, el-collapse, el-timeline, el-divider, el-calendar, el-image, el-backtop,v-infinite-scroll, el-drawer等

示例背景

在做vue项目时候,有的需求是将一维的对象数组转换成二维的对象数组,怎么操作呢? 在本示例中,按照时间的划分,将一维对象数组转化为二维对象数组。第一维度的内容是时间,第二纬度的内容是一维数组中的某一项。

示例效果图

065:vue中将一维对象数组转换为二维对象数组,# vue2常用示例500+,vue.js,elementui,vue数组转换,一维数组转换为二维数组文章来源地址https://www.toymoban.com/news/detail-782921.html

示例源代码

/*
* @Author: 大剑师兰特(xiaozhuanlan),还是大剑师兰特(CSDN)
* @此源代码版权归大剑师兰特所有,可供学习或商业项目中借鉴,未经授权,不得重复地发表到博客、论坛,问答,git等公共空间或网站中。
* @Email: 2909222303@qq.com
* @weixin: gis-dajianshi
* @First published in CSDN
* @First published time: 2024-01-12
*/

<template>
	<div class="djs-box">
		<div class="topBox">
			<h3>vue项目中 将一维对象数组转换为二维对象数组 </h3>
			<div>大剑师兰特, 还是大剑师兰特,gis-dajianshi</div>
			<h4>
				<el-button @click="go()" type="primary" size="mini"> 转换数据</el-button>
			</h4>
		</div>
		<div class="dajianshi">
			<div class="left">
				<h4>变换后的一维数组</h4>
				<p v-for="(item,index) in arr1" :key="index"> 时间:{{item.time}}- 年份:{{item.year}}- 原索引:{{item.indexId}}
				</p>
			</div>

			<div class="right">
				<h4>变成二维数组</h4>
				<div v-for="(item1,index1) in arr2" :key="index1"> ● 时间:{{item1.time}}
					<div v-for="(item2,index2) in item1.children" :key="index2" class="lh30">
						&nbsp;&nbsp;&nbsp;&nbsp; 内容:{{item2.info}}-代号-{{item2.code}} -- 原索引:{{item2.indexId}}-时间:{{item2.time}}
					</div>
				</div>
			</div>

		</div>

	</div>
</template>

<script>
	export default {
		data() {
			return {
				arr: [{
						'time': '2023-12-07',
						'code': 'S10',
						'gname': 'G10',
						'info': '大剑师1'
					},
					{
						'time': '2023-12-07',
						'code': 'S10',
						'gname': 'G10',
						'info': '大剑师2'
					},
					{
						'time': '2023-12-07',
						'code': 'S11',
						'gname': 'G11',
						'info': '大剑师3'
					},
					{
						'time': '2023-12-08',
						'code': 'S10',
						'gname': 'G10',
						'info': '大剑师4'
					},
					{
						'time': '2023-12-08',
						'code': 'S11',
						'gname': 'G11',
						'info': '大剑师5'
					},
					{
						'time': '2023-12-09',
						'code': 'S12',
						'gname': 'G12',
						'info': '大剑师6'
					}
				],
				arr1: [],
				arr2: [],
			}
		},
		mounted() {
			this.arr1 = this.dajianshi_arr1to1(this.arr)
		},

		methods: {
			go() {

				this.arr2 = this.dajianshi_arr1to2(this.arr1)
				console.log(this.arr2)
			},
			dajianshi_arr1to1(arr) {
				let newArr = arr.map((item, index) => {
					return {
						...item,
						indexId: index,
						year: item.time.substr(0, 4),
					}
				})
				return newArr;
			},

			dajianshi_arr1to2(arr) {
				let keys = Object.keys(arr[0])
				let level1 = 'time' //获取一级属性名称
				let list = Array.from(new Set(
					arr.map(item => {
						return item[level1]
					})))
				let subList = []
				list.forEach(res => {
					arr.forEach(ele => {
						if (ele[level1] === res) {
							let nameArr = subList.map(item => item.time)
							if (nameArr.indexOf(res) !== -1) {
								subList[nameArr.indexOf(res)].children.push({
									...ele
								})

			  	        	} else {
								subList.push({
									time: res,
									// label: res,
									children: [{
											...ele										
									}]
								})
							}
						}
					})

				})
				return subList
			}

		}
	}
</script>
<style scoped>
	.djs-box {
		width: 1000px;
		height: 680px;
		margin: 50px auto;
		border: 1px solid peru;
	}

	.topBox {
		margin: 0 auto 0px;
		padding: 10px 0 20px;
		background: peru;
		color: #fff;
	}

	.dajianshi {
		width: 98%;
		height: 480px;
		margin: 5px auto 0;
	}
    .lh30{ line-height: 30px;}
	.left {
		width: 50%;
		height: 100%;
		float: left;
		overflow-y: auto;
		background: #fed;
	}

	.right {
		width: 50%;
		height: 100%;
		float: left;
		overflow-y: auto;
		background: #edc;
		text-align: left;
		padding-left: 15px;
		box-sizing: border-box;
	}
</style>


到了这里,关于065:vue中将一维对象数组转换为二维对象数组的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • vue2修改数组或对象,但视图不刷新

    问题:我们在vue2开发过程中会碰到数据更新,但是页面并未改变的情况,原因如下:         第一种:动态给对象新增属性或者删除属性是不会触发视图刷新的,Vue识别不到;         第二种:通过数组下标修改数组中的元素或者手动修改数组的长度,Vue识别不到;   解决

    2024年02月11日
    浏览(25)
  • 【013】C++数组之一维数值数组和二维数值数组

    💡 作者简介:专注于C/C++高性能程序设计和开发,理论与代码实践结合,让世界没有难学的技术。包括C/C++、Linux、MySQL、Redis、TCP/IP、协程、网络编程等。 👉 🎖️ CSDN实力新星,社区专家博主 👉 🔔 专栏介绍:从零到c++精通的学习之路。内容包括C++基础编程、中级编程、

    2024年02月06日
    浏览(43)
  • C语言中一维数组及二维数组的运用

    int * p  = arr; int * q = arr[1]; 其中arr是数组名,代表了整个数组的首元素地址,这个是一个常量,放在常量存储区,所以在给int*p赋值的时候可以不用带,而下面的arr[1]则代表数组里的某一个元素,所以在赋值时要加上  有个例题: 下列运行结果  解析:首先看main函数里的第二

    2024年02月13日
    浏览(35)
  • 【C语言】利用数组处理批量数据(一维数组和二维数组)

    前言 :在前面学习的程序中使用的变量都属于基本类型,例如整型、字符型、浮点型数据,这些都是简单的数据类型。对于简单的问题,使用这些简单的数据类型就可以了。但是对于有些需要处理的数据,只用以上简单的数据类型是不够的,难以反映出数据的特点,也难以有

    2024年02月08日
    浏览(42)
  • 头歌——一维数组和二维数组全对答案秒过

    我相信大家都会,只是整个乱七八糟的事太多了,发布这个文章的目的不是让你去抄袭,而是去学习,不要说我传播啊,服了这个文章建议怎么还不消掉,难道他看出我在摸鱼了吗?虽然我现在就两个粉丝,嗯,这几天可以看出我更新不是很积极,主要是一直再写学生管理系

    2024年02月04日
    浏览(31)
  • 微信小程序数组对象的添加及删除(Vue2)

    数组添加元素的两个方法(都不去重) 1、数组.push(对象) 直接向数组末尾追加新的元素(不会去重) 使用push添加数组时会将整个数组直接加入数组之中 1、数组.concat(对象) 使用concat会将要追加的数据(数组)进行拆分以此追加到数据末尾 追加相同的数据 追加一组数组 3.数

    2024年02月11日
    浏览(32)
  • vue 数组转对象与对象转数组(对象与数组的相互转换)

    转换前为数组: 转换为对象的效果图:  

    2024年02月03日
    浏览(29)
  • 《C语言深度解剖》(4):深入理解一维数组和二维数组

    🤡博客主页:醉竺 🥰 本文专栏: 《C语言深度解剖》 😻 欢迎关注: 感谢大家的点赞评论+关注,祝您学有所成! ✨✨💜💛想要学习更多 数据结构与算法 点击专栏链接查看💛💜✨✨   数组是一组相同类型元素的集合。 数组的创建方式:  数组创建的实例:  注:数组

    2024年04月09日
    浏览(74)
  • Python基础 - 将二维列表转换为一维

    在实验中经常会遇到将二维列表(数组)拉平到一维,如将 [[1, 1], [2, 2]] 转换为[1, 1, 2, 2],有以下几种操作方案: 1. 最简单的直接使用循环,如下: 2. 使用itertools.chain(*iterables),能够去除iterable里的内嵌的一层iterable【注意:只能去除一层,多的层数去除不了,具体实例可看下

    2024年02月06日
    浏览(29)
  • C语言中函数返回数组(一维和二维)

    C语言中函数返回数组是很重要的一种应用,有时候在程序中调用函数返回数组可以更容易的实现我们想要的某些操作,比如一次返回多个值,这篇文章带来的是C语言中函数返回一维数组和二维数组的例子。 函数返回一维数组中需要注意的是:定义函数时需要在函数类型的后

    2024年02月04日
    浏览(37)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包