递归格式化省市区三级联动数据

原数据格式:china-area-data组件下的data.json数据。

目标数据格式:依照elementUI的Cascader 级联选择器所需要的options格式。

//citysFormat.js
const fs = require("fs");


	var destArr = []; //目标对象
	var orginArr = {}; //初始对象

fs.readFile("./jstest/data.json","utf-8",(err,data)=>{
	if(err)
		throw err;
	
	orginArr = 	JSON.parse(data.toString());
	
	formatArr(orginArr['86'],destArr); //递归转换


//转换到目标格式的数据,写入到本地文件
	fs.writeFile('newData.txt', JSON.stringify(destArr), (err) => {
		if (err) throw err;
		console.log('The file has been saved!');
	  });

})



/**
 * 递归拼接
 * {value: 'root',
	  label: '一级标题',
	  children: [{
		  value:'child',
		  label:'二级标题',
		  children:[{
			  value:'child-child',
			  label:'三级标题'
		  }]
	  }
	}
 * @param {Object} orginJson 
 * @param {Object} destJson 
 */
function formatArr(orginJson,destarr){
	
	if(orginJson){
		for(var value in orginJson){zhan
			
			var destJson = {};
			
			destJson['value']= value;
			destJson['label'] = orginJson[value];
			destarr.push(destJson);

			
			if(orginArr[value]){ //下一级有值,继续递归
				destJson['children'] = []; //把下一级递归的对象作为当前对象的children
				formatArr(orginArr[value],destJson['children']);
			}
			
		}

	}
	

	
}

展示效果:
在这里插入图片描述

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值