根据json数组对象中的某一属性进行分类

前端在跟后台对接口时 经常会发现后台返回的json数组并不是自己想要的格式,这样就需要前端自己(后台不想改的情况下)对数据进行处理

例:根据pid进行分类 方便我对循环 渲染dom

示例图片

处理后的数据:

处理后的数据

实现方法:

			var typeInfo = [{
				"id": 18,
				"pid": 17,
				"name": " 快手",
				"pname": "微博",
				"order": 0,
				"title": "【小红书】点赞+收藏",
				"img": "http://whb.yqin.cn/upload/admin/20190822/b3d3ba34eaceaff6d0cd9f9315014c39.png",
				"dmoney": "0.20"

			}, {
				"id": 16,
				"pid": 15,
				"name": "抖音",
				"pname": "小红书点赞+收藏",
				"order": 0,
				"title": "【抖音】提示:此处输入,点赞+评论",
				"img": "http://whb.yqin.cn/upload/admin/20190822/5fa8d7447f637f78da8d65608afdc1c4.png",
				"dmoney": "0.20"

			}, {
				"id": 17,
				"pid": 15,
				"name": "微博",
				"pname": "小红书点赞+收藏",
				"order": 0,
				"title": "【微博】提示:此处输入,点赞+收藏",
				"img": "http://whb.yqin.cn/upload/admin/20190822/07737ae6ac4938806ea69b796e166dd6.png",
				"dmoney": "0.20"

			}, {
				"id": 21,
				"pid": 17,
				"name": "火山",
				"pname": "微博",
				"title": "【火山】列入点赞+评论",
				"content": "",
				"img": "http://whb.yqin.cn/upload/admin/20190822/e06b716f453dc6af6db07edc7fcc8122.png",
				"dmoney": "0.20"
			}];
			if (typeInfo.length > 0) {
			  var map = {},dest = [];
				for(var i = 0; i < typeInfo.length; i++){
					 var ai = typeInfo[i];
					 if (!map[ai.pid]) {
						 dest.push({
							 pid: ai.pid,
							 data: [ai]
						 });
						 map[ai.pid] = ai;
					 } else {
						 for (var j = 0; j < dest.length; j++) {
							 var dj = dest[j];
							 if (dj.pid == ai.pid) {
								 dj.data.push(ai);
								 break;
							 }
						 }
					 }
				}
			}
             console.log(dest)

 

 

 

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值