使用node修改適合element-ui地區(qū)選擇器的數(shù)據(jù)

需求

最近在做關(guān)于地區(qū)的的選擇撒穷,使用的是element-ui中的el-cascader級聯(lián)選擇器控件,要按照大區(qū)->省->市這種關(guān)系進行組合敛纲,控件需要的內(nèi)容是:

        [{
          value: 'zhinan',
          label: '指南',
          children: [{
            value: 'shejiyuanze',
            label: '設(shè)計原則',
            children: [{
              value: 'yizhi',
              label: '一致'
            }, {
              value: 'fankui',
              label: '反饋'
            }, {
              value: 'xiaolv',
              label: '效率'
            }, {
              value: 'kekong',
              label: '可控'
            }]
          }, {
            value: 'daohang',
            label: '導(dǎo)航',
            children: [{
              value: 'cexiangdaohang',
              label: '側(cè)向?qū)Ш?
            }, {
              value: 'dingbudaohang',
              label: '頂部導(dǎo)航'
            }]
          }]
        }, {
          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 圖標(biāo)'
            }, {
              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 計數(shù)器'
            }, {
              value: 'select',
              label: 'Select 選擇器'
            }, {
              value: 'cascader',
              label: 'Cascader 級聯(lián)選擇器'
            }, {
              value: 'switch',
              label: 'Switch 開關(guān)'
            }, {
              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這個庫的數(shù)據(jù)遣钳,但是沒有大區(qū)的,所以首先定義大區(qū)(自己定義)
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中可以下載肃叶,因為不需要用到直轄市的區(qū),所以我分別下載省級和地級的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));


//組合省和市的數(shù)據(jù)
var arr = provincesRes.map(provincesVal => {
  provincesVal.children = [];
  cityRes.map(cityVal => {
    if (provincesVal.code === cityVal.provinceCode) {
      delete cityVal.provinceCode;
      provincesVal.children.push(cityVal);
    }
  });
  return provincesVal;
});

//組合大區(qū)因惭、省和市的數(shù)據(jù)
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;
});

//把數(shù)據(jù)寫入文件
fs.writeFile("address.json", JSON.stringify(address), function(err) {
  if (err) {
    return console.error(err);
  }
  console.log("數(shù)據(jù)寫入成功!");
  fs.readFile("address.json", function(err, data) {
    if (err) {
      return console.error(err);
    }
    console.log("異步讀取文件數(shù)據(jù): " + data.toString());
  });
});

使用

執(zhí)行

node index.js

因為生成json中的key跟控件中不一樣绩衷,這邊我直接使用編譯器去全局替換了

code --> value
name --> label

最后導(dǎo)入json文件使用,效果如下

image
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末筛欢,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子唇聘,更是在濱河造成了極大的恐慌版姑,老刑警劉巖,帶你破解...
    沈念sama閱讀 218,386評論 6 506
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件迟郎,死亡現(xiàn)場離奇詭異剥险,居然都是意外死亡,警方通過查閱死者的電腦和手機宪肖,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,142評論 3 394
  • 文/潘曉璐 我一進店門表制,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人控乾,你說我怎么就攤上這事么介。” “怎么了蜕衡?”我有些...
    開封第一講書人閱讀 164,704評論 0 353
  • 文/不壞的土叔 我叫張陵壤短,是天一觀的道長。 經(jīng)常有香客問我,道長久脯,這世上最難降的妖魔是什么纳胧? 我笑而不...
    開封第一講書人閱讀 58,702評論 1 294
  • 正文 為了忘掉前任,我火速辦了婚禮帘撰,結(jié)果婚禮上跑慕,老公的妹妹穿的比我還像新娘。我一直安慰自己摧找,他們只是感情好核行,可當(dāng)我...
    茶點故事閱讀 67,716評論 6 392
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著蹬耘,像睡著了一般芝雪。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上婆赠,一...
    開封第一講書人閱讀 51,573評論 1 305
  • 那天绵脯,我揣著相機與錄音佳励,去河邊找鬼休里。 笑死,一個胖子當(dāng)著我的面吹牛赃承,可吹牛的內(nèi)容都是我干的妙黍。 我是一名探鬼主播,決...
    沈念sama閱讀 40,314評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼瞧剖,長吁一口氣:“原來是場噩夢啊……” “哼拭嫁!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起抓于,我...
    開封第一講書人閱讀 39,230評論 0 276
  • 序言:老撾萬榮一對情侶失蹤做粤,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后捉撮,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體怕品,經(jīng)...
    沈念sama閱讀 45,680評論 1 314
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,873評論 3 336
  • 正文 我和宋清朗相戀三年巾遭,在試婚紗的時候發(fā)現(xiàn)自己被綠了肉康。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 39,991評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡灼舍,死狀恐怖吼和,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情骑素,我是刑警寧澤炫乓,帶...
    沈念sama閱讀 35,706評論 5 346
  • 正文 年R本政府宣布,位于F島的核電站,受9級特大地震影響厢岂,放射性物質(zhì)發(fā)生泄漏光督。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 41,329評論 3 330
  • 文/蒙蒙 一塔粒、第九天 我趴在偏房一處隱蔽的房頂上張望结借。 院中可真熱鬧,春花似錦卒茬、人聲如沸船老。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,910評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽柳畔。三九已至,卻和暖如春郭赐,著一層夾襖步出監(jiān)牢的瞬間薪韩,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 33,038評論 1 270
  • 我被黑心中介騙來泰國打工捌锭, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留俘陷,地道東北人。 一個月前我還...
    沈念sama閱讀 48,158評論 3 370
  • 正文 我出身青樓观谦,卻偏偏與公主長得像拉盾,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子豁状,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 44,941評論 2 355

推薦閱讀更多精彩內(nèi)容

  • 最惱人的是好不容易編上一條代碼捉偏,卻發(fā)現(xiàn)視覺上有種說不出來的不舒適感~~~ 哈哈哈,感覺扯偏了泻红,現(xiàn)在記下自己調(diào)pyc...
    果果求學(xué)者閱讀 2,854評論 0 0
  • 今天我在網(wǎng)上看到了一個作文夭禽,是寫科技小論文的,內(nèi)容是: 找來一個紙杯谊路,一張大小合適的白紙讹躯,接著將杯子裝滿了水,將拿...
    沒有沒有沒有沒有閱讀 159評論 0 0