使用node修改适合element-ui地区选择器的数据

需求

最近在做关于地区的的选择,使用的是element-ui中的el-cascader级联选择器控件,要按照大区->省->市这种关系进行组合,控件需要的内容是:

        [{
          value: 'zhinan',
          label: '指南',
          children: [{
            value: 'shejiyuanze',
            label: '设计原则',
            children: [{
              value: 'yizhi',
              label: '一致'
            }, {
              value: 'fankui',
              label: '反馈'
            }, {
              value: 'xiaolv',
              label: '效率'
            }, {
              value: 'kekong',
              label: '可控'
            }]
          }, {
            value: 'daohang',
            label: '导航',
            children: [{
              value: 'cexiangdaohang',
              label: '侧向导航'
            }, {
              value: 'dingbudaohang',
              label: '顶部导航'
            }]
          }]
        }, {
          value: 'zujian',
          label: '组件',
          children: [{
            value: 'basic',
            label: 'Basic',
            children: [{
              value: 'layout',
              label: 'Layout 布局'
            }, {
              value: 'color',
              label: 'Color 色彩'
            }, {
              value: 'typography',
              label: 'Typography 字体'
            }, {
              value: 'icon',
              label: 'Icon 图标'
            }, {
              value: 'button',
              label: 'Button 按钮'
            }]
          }, {
            value: 'form',
            label: 'Form',
            children: [{
              value: 'radio',
              label: 'Radio 单选框'
            }, {
              value: 'checkbox',
              label: 'Checkbox 多选框'
            }, {
              value: 'input',
              label: 'Input 输入框'
            }, {
              value: 'input-number',
              label: 'InputNumber 计数器'
            }, {
              value: 'select',
              label: 'Select 选择器'
            }, {
              value: 'cascader',
              label: 'Cascader 级联选择器'
            }, {
              value: 'switch',
              label: 'Switch 开关'
            }, {
              value: 'slider',
              label: 'Slider 滑块'
            }, {
              value: 'time-picker',
              label: 'TimePicker 时间选择器'
            }, {
              value: 'date-picker',
              label: 'DatePicker 日期选择器'
            }, {
              value: 'datetime-picker',
              label: 'DateTimePicker 日期时间选择器'
            }, {
              value: 'upload',
              label: 'Upload 上传'
            }, {
              value: 'rate',
              label: 'Rate 评分'
            }, {
              value: 'form',
              label: 'Form 表单'
            }]
          }]

解决办法

我使用的是Administrative-divisions-of-China这个库的数据,但是没有大区的,所以首先定义大区(自己定义)
region.json

//  provinces:省的code码
[{
    "code": "10001",
    "name": "东北",
    "provinces": ["21", "22", "23"]
}, {
    "code": "10002",
    "name": "华东",
    "provinces": ["31", "32", "33", "34", "35", "36", "37"]
}, {
    "code": "10003",
    "name": "华北",
    "provinces": ["11", "12", "13", "14", "15"]
}, {
    "code": "10004",
    "name": "华中",
    "provinces": ["41", "42", "43"]
}, {
    "code": "10005",
    "name": "华南",
    "provinces": ["44", "45", "46"]
}, {
    "code": "10006",
    "name": "西南",
    "provinces": ["50", "51", "52", "53", "54"]
}, {
    "code": "10007",
    "name": "西北",
    "provinces": ["61", "62", "63", "64", "65"]
}]

省和市的json在Administrative-divisions-of-China中可以下载,因为不需要用到直辖市的区,所以我分别下载省级和地级的json文件,自己拼接了

image

index.js代码如下

var fs = require("fs");
var cityFile = "./city.json";
var provincesFile = "./provinces.json";
var regionFile = "./region.json";

//同步加载json文件
var cityRes = JSON.parse(fs.readFileSync(cityFile));
var provincesRes = JSON.parse(fs.readFileSync(provincesFile));
var regionRes = JSON.parse(fs.readFileSync(regionFile));


//组合省和市的数据
var arr = provincesRes.map(provincesVal => {
  provincesVal.children = [];
  cityRes.map(cityVal => {
    if (provincesVal.code === cityVal.provinceCode) {
      delete cityVal.provinceCode;
      provincesVal.children.push(cityVal);
    }
  });
  return provincesVal;
});

//组合大区、省和市的数据
var address = regionRes.map(val => {
  val.children = [];
  val.provinces.forEach(element => {
    arr.map(val1 => {
      if (element === val1.code) {
        val.children.push(val1);
      }
    });
  });
  delete val.provinces;
  return val;
});

//把数据写入文件
fs.writeFile("address.json", JSON.stringify(address), function(err) {
  if (err) {
    return console.error(err);
  }
  console.log("数据写入成功!");
  fs.readFile("address.json", function(err, data) {
    if (err) {
      return console.error(err);
    }
    console.log("异步读取文件数据: " + data.toString());
  });
});

使用

执行

node index.js

因为生成json中的key跟控件中不一样,这边我直接使用编译器去全局替换了

code --> value
name --> label

最后导入json文件使用,效果如下

image
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 158,736评论 4 362
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 67,167评论 1 291
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 108,442评论 0 243
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 43,902评论 0 204
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 52,302评论 3 287
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 40,573评论 1 216
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 31,847评论 2 312
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 30,562评论 0 197
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 34,260评论 1 241
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 30,531评论 2 245
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 32,021评论 1 258
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 28,367评论 2 253
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 33,016评论 3 235
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 26,068评论 0 8
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 26,827评论 0 194
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 35,610评论 2 274
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 35,514评论 2 269

推荐阅读更多精彩内容

  • 最恼人的是好不容易编上一条代码,却发现视觉上有种说不出来的不舒适感~~~ 哈哈哈,感觉扯偏了,现在记下自己调pyc...
    果果求学者阅读 2,794评论 0 0
  • 今天我在网上看到了一个作文,是写科技小论文的,内容是: 找来一个纸杯,一张大小合适的白纸,接着将杯子装满了水,将拿...
    沒有沒有沒有沒有阅读 148评论 0 0