<em>Mac</em>Book项目 2009年学校开始实施<em>Mac</em>Book项目,所有师生配备一本<em>Mac</em>Book,并同步更新了校园无线网络。学校每周进行电脑技术更新,每月发送技术支持资料,极大改变了教学及学习方式。因此2011
2021-06-01 09:32:01
今天在專案中需要通過行政區域選擇,然後選擇該行政區域下面的景區,也就是要構建行政區劃、景區兩表資料表的樹。
全國的行政區域到縣已經3500多了,再加上景區會有幾萬個點,這棵選擇樹不論是在後臺還是在前臺構建都比較大,會影響系統效能,需要前後端結合,動態構建,使用時用懶載入,提升系統效能。
1、行政區域需要按省、市、縣的adcode和級別查詢,以便於動態構建。
兩個引數,adcode後臺查詢時會將後面的0去掉匹配,級別如果0或空,查詢匹配下所有的,為數位只查本級。
這裡有兩個引數,用@requestParam傳遞的,注意要用post,前端VUE使用get傳遞時會報錯。
@PostMapping("/listjson" ) @ApiOperation("根據查詢條件獲取區劃清單") public AjaxResult listJson(@RequestParam(name="adcode", required = true) String adcode, @RequestParam(name="level",required = true) String level) { System.out.println(adcode); List<Map<String, String>> regionJson = iMapRegionService.selectRegionJson(adcode,level); return AjaxResult.success(regionJson); } }
2、查詢行政區域下的景區,根據adcode查詢,一個引數,引數放在路徑中傳遞的。
@GetMapping("/listByCode/{adcode}") @ApiOperation("根據查詢條件獲取景區清單") public AjaxResult listByCode(@PathVariable String adcode) { List<Map<String, String>> scenicList = iMapScenicService.selectScenicByCode(adcode); return AjaxResult.success(scenicList); } }
由於後面要用懶載入,在參照Treeselect給件同時,還要引入LOAD_CHILDREN_OPTIONS,Treeselect要加到components中。
import { LOAD_CHILDREN_OPTIONS, Treeselect } from '@riophae/vue-treeselect' import '@riophae/vue-treeselect/dist/vue-treeselect.css' export default { components: { Treeselect }, data() { return { //地點列表 regionOptions: [],
noChildrenText=「更新中…」 , //由於預設會將沒有載入下級節點的children設定為null,系統預設會顯示No sub-options,點選節點是,顯示更新中更好,更新完成顯示子節點。 :load-options=「loadOptions」 //增加此選項,在後方擴充套件子節點是會呼叫此方法,第一是點選左邊的三解形,第二下面將非葉子節點設定為不能選擇,點選節點也會自動擴充套件。 :disable-branch-nodes=「true」> //將樹枝節點設定為不能選擇,樹枝節點是行政區域,也不我們需要的景區ID,所以不能選擇,否則資料會亂。
<el-form-item label="景區名稱" prop="scenicId"> <treeselect v-model="form.scenicId" :options="regionOptions" noChildrenText="更新中..." :load-options="loadOptions" placeholder="請選擇景區" :disable-branch-nodes="true"> </treeselect> </el-form-item>
元件開啟初始化時,構建一級選擇樹
created() { this.getList() this.getTreeselect() }, methods: { /** 生成查詢行政區劃下拉樹結構第一級 */ getTreeselect() { let formData = new FormData() //構建需要查詢的引數,先選擇省節點 formData.append('adcode', '000000') formData.append('level', '1') listJson(formData).then(response => { //listJson對應是詢後臺行政區域的介面函數 let data = response.data data.forEach(element => { element['id'] = element.code // 後臺傳遞過來的是code和name,需要換為treeselect所需要的id和label element['label'] = element.name element['level'] = '1' //設定為1級,後續判斷需要 element['children'] = null //要設定為空,才能觸發:load-options="loadOptions"動用 }) this.regionOptions = data }) },
//動態新增樹的子節點 loadOptions({ action, parentNode, callback }) { if (action === LOAD_CHILDREN_OPTIONS) { let formData = new FormData() formData.append('adcode', parentNode.id) switch (parentNode.level) { //判斷選擇級別 case '1' : /** 生成查詢行政區劃下拉樹結構第二級 */ formData.append('level', '2') listJson(formData).then(res => { //選擇市,構建2級 if (res.code === 200) { //後臺返回是用code表示返回狀態程式碼,與後臺匹配 let data = res.data data.forEach(element => { element['id'] = element.code element['label'] = element.name element['level'] = '2' element['children'] = null }) parentNode.children = data //增加子節點 } }) callback() break case '2' : /** 生成查詢行政區劃下拉樹結構第三級 */ formData.append('level', '3') listJson(formData).then(res => { if (res.code === 200) { let data = res.data data.forEach(element => { element['id'] = element.code element['label'] = element.name element['level'] = '3' element['children'] = null }) parentNode.children = data } }) callback() break case '3' : /** 生成查詢行政區下的景區清單 */ listByCode(parentNode.id).then(res => { //第四級是景區,使用的是景區表,根據adcode查詢 if (res.code === 200) { let data = res.data console.log(data) data.forEach(element => { //為景區增加一個圖示,以示區別 element['label'] = element['label'] + '' //使用emoji檔案,標識這是景區,treeselect沒有icon圖示 element['level'] = '4' }) parentNode.children = data } }) callback() break } } }
這個方法動態實現Treeselect構建,可以解決巨樹構建問題。
以上為個人經驗,希望能給大家一個參考,也希望大家多多支援it145.com。
相關文章
<em>Mac</em>Book项目 2009年学校开始实施<em>Mac</em>Book项目,所有师生配备一本<em>Mac</em>Book,并同步更新了校园无线网络。学校每周进行电脑技术更新,每月发送技术支持资料,极大改变了教学及学习方式。因此2011
2021-06-01 09:32:01
综合看Anker超能充系列的性价比很高,并且与不仅和iPhone12/苹果<em>Mac</em>Book很配,而且适合多设备充电需求的日常使用或差旅场景,不管是安卓还是Switch同样也能用得上它,希望这次分享能给准备购入充电器的小伙伴们有所
2021-06-01 09:31:42
除了L4WUDU与吴亦凡已经多次共事,成为了明面上的厂牌成员,吴亦凡还曾带领20XXCLUB全队参加2020年的一场音乐节,这也是20XXCLUB首次全员合照,王嗣尧Turbo、陈彦希Regi、<em>Mac</em> Ova Seas、林渝植等人全部出场。然而让
2021-06-01 09:31:34
目前应用IPFS的机构:1 谷歌<em>浏览器</em>支持IPFS分布式协议 2 万维网 (历史档案博物馆)数据库 3 火狐<em>浏览器</em>支持 IPFS分布式协议 4 EOS 等数字货币数据存储 5 美国国会图书馆,历史资料永久保存在 IPFS 6 加
2021-06-01 09:31:24
开拓者的车机是兼容苹果和<em>安卓</em>,虽然我不怎么用,但确实兼顾了我家人的很多需求:副驾的门板还配有解锁开关,有的时候老婆开车,下车的时候偶尔会忘记解锁,我在副驾驶可以自己开门:第二排设计很好,不仅配置了一个很大的
2021-06-01 09:30:48
不仅是<em>安卓</em>手机,苹果手机的降价力度也是前所未有了,iPhone12也“跳水价”了,发布价是6799元,如今已经跌至5308元,降价幅度超过1400元,最新定价确认了。iPhone12是苹果首款5G手机,同时也是全球首款5nm芯片的智能机,它
2021-06-01 09:30:45