日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

您的位置:首頁技術(shù)文章
文章詳情頁

Vue 級聯(lián)下拉框的設(shè)計與實現(xiàn)

瀏覽:62日期:2022-09-28 10:57:04
目錄1.數(shù)據(jù)庫設(shè)計2.前端頁面3.一個完整的demo

​ 在前端開發(fā)中,級聯(lián)選擇框是經(jīng)常用到的,這樣不僅可以增加用戶輸入的友好性,還能減少前后端交互的數(shù)據(jù)量。本文以elementUI為例,使用其余UI組件大致思想也都相同。

1.數(shù)據(jù)庫設(shè)計

​ 所有的相關(guān)數(shù)據(jù)皆可存在一張表中,這樣數(shù)據(jù)就可以不受層級的限制。

​ 表結(jié)構(gòu)可以參考如下建表SQL:

CREATE TABLE `supplies_type` ( `id` int(11) NOT NULL AUTO_INCREMENT, `category_type` varchar(64) NOT NULL COMMENT ’類別種類:大類、中類、小類’, `big_category_name` varchar(64) NOT NULL COMMENT ’大類名稱’, `middle_category_name` varchar(64) DEFAULT NULL COMMENT ’中類名稱’, `small_category_name` varchar(64) DEFAULT NULL COMMENT ’小類名稱’, `parent_id` int(11) DEFAULT NULL, `create_time` timestamp NULL DEFAULT CURRENT_TIMESTAMP, `create_user_name` varchar(64) DEFAULT NULL COMMENT ’創(chuàng)建人用戶名’, `update_time` timestamp NULL DEFAULT NULL ON UPDATE CURRENT_TIMESTAMP, `is_deleted` tinyint(1) DEFAULT ’0’ COMMENT ’是否刪除,1表示已刪除’, PRIMARY KEY (`id`)) ENGINE=InnoDB AUTO_INCREMENT=1 DEFAULT CHARSET=utf8mb4;

數(shù)據(jù)庫截圖如下圖所示,注:本系統(tǒng)為了減少查詢次數(shù),故冗余了一些字段,讀者可根據(jù)自己的需求調(diào)整。

Vue 級聯(lián)下拉框的設(shè)計與實現(xiàn)

核心設(shè)計在于parent_id,根據(jù)parent_id字段即可查詢到子類,結(jié)果如下圖所示:

Vue 級聯(lián)下拉框的設(shè)計與實現(xiàn)

Vue 級聯(lián)下拉框的設(shè)計與實現(xiàn)

2.前端頁面

​ 前端頁面效果如下:

Vue 級聯(lián)下拉框的設(shè)計與實現(xiàn)

Html代碼如下:

<div class='app-container'> <span style='margin-left:120px;margin-right: 20px;width: 150px;display: inline-block;'>大類:</span> <el-select v-model='big' placeholder='請選擇' @change='getSuppliesType(big)' style='width: 19%;'> <el-optionv-for='item in bigTypes':key='item.bigCategoryName':label='item.bigCategoryName':value='item.id'> </el-option> </el-select> <span style='margin-left:120px;margin-right: 20px; width: 150px;display: inline-block;'>中類:</span> <el-select v-model='middle' placeholder='請選擇' @change='getSuppliesType(middle)' style='width: 19%;'> <el-optionv-for='item in middleTypes':key='item.middleCategoryName':label='item.middleCategoryName':value='item.id'> </el-option> </el-select> <br> <br> <br> <span style='margin-left:120px;margin-right: 20px;width: 150px; margin-top:20px; display: inline-block;'>小類:</span> <el-select v-model='small' placeholder='請選擇' style='width: 19%;'> <el-optionv-for='item in smallTypes':key='item.smallCategoryName':label='item.smallCategoryName':value='item.id'> </el-option> </el-select></div>

​ 上面的item.smallCategoryName、item.smallCategoryName數(shù)據(jù)為后端從數(shù)據(jù)庫中查詢出來的數(shù)據(jù)(駝峰命名),后端只負(fù)責(zé)查詢、并返回結(jié)果。

Vue中數(shù)據(jù)定義如下:

data() { return {big: ’’,bigTypes: null,middle: ’’,middleTypes: null,small: ’’,smallTypes: null }},

在頁面初始化時,自動獲取大類列表:

created() {this.getSuppliesType(0)},

頁面中的getSuppliesType方法如下:

getSuppliesType(id) { this.listLoading = true const queryData = { parentId: id } //此處的調(diào)用后端接口按照自己的調(diào)用方式寫即可 //此處的getSuppliersType是項目中自己封裝的util中的方法 //如果請求方式是post,JSON.stringify(queryData) //如果請求方式是get,queryData getSuppliersType(JSON.stringify(queryData)).then(response => { console.log(response) console.log(response.data[0].categoryType) //根據(jù)type自動向三個下拉框賦值 if (response.data[0].categoryType === ’BIG’) { this.bigTypes = response.data } else if (response.data[0].categoryType === ’MIDDLE’) { this.middleTypes = response.data } else { this.smallTypes = response.data } this.listLoading = false }).catch(function (error) { console.log(error) this.listLoading = false })},3.一個完整的demo

​ 下面這個頁面為完成代碼,其中的數(shù)據(jù)為部分?jǐn)?shù)據(jù),后臺接口獲取使用JS來完成。

<template> <div class='app-container'> <span style='margin-left:120px;margin-right: 20px;width: 150px;display: inline-block;'>大類:</span> <el-select v-model='big' placeholder='請選擇' @change='getSuppliesType(big)' style='width: 19%;'> <el-optionv-for='item in bigTypes':key='item.bigCategoryName':label='item.bigCategoryName':value='item.id'> </el-option> </el-select> <span style='margin-left:120px;margin-right: 20px; width: 150px;display: inline-block;'>中類:</span> <el-select v-model='middle' placeholder='請選擇' @change='getSuppliesType(middle)' style='width: 19%;'> <el-optionv-for='item in middleTypes':key='item.middleCategoryName':label='item.middleCategoryName':value='item.id'> </el-option> </el-select> <br> <br> <br> <span style='margin-left:120px;margin-right: 20px;width: 150px; margin-top:20px; display: inline-block;'>小類:</span> <el-select v-model='small' placeholder='請選擇' style='width: 19%;'> <el-optionv-for='item in smallTypes':key='item.smallCategoryName':label='item.smallCategoryName':value='item.id'> </el-option> </el-select> <br> <br> <br> <el-button type='primary' round @click.native.prevent='commit'>添加</el-button> <el-button type='primary' round @click.native.prevent='cancel'>取消</el-button> </div></template><script> export default {filters: { parseTime(timestamp) {return parseTime(timestamp, null) }},data() { return {big: ’’,bigTypes: null,middle: ’’,middleTypes: null,small: ’’,smallTypes: null,dataList: [ {'id':1,'categoryType':'BIG','bigCategoryName':'1.現(xiàn)場管理與保障','middleCategoryName':null,'smallCategoryName':null,'parentId':0,'createTime':'2021-07-04T11:13:36.000+0000','createUserName':null,'updateTime':'2021-07-04T13:34:31.000+0000','isDeleted':false}, {'id':27,'categoryType':'BIG','bigCategoryName':'2.生命救援與生活救助','middleCategoryName':null,'smallCategoryName':null,'parentId':0,'createTime':'2021-07-04T11:13:36.000+0000','createUserName':null,'updateTime':null,'isDeleted':false}, {'id':2,'categoryType':'MIDDLE','bigCategoryName':'1.現(xiàn)場管理與保障','middleCategoryName':'1.1現(xiàn)場監(jiān)測','smallCategoryName':null,'parentId':1,'createTime':'2021-07-04T11:13:36.000+0000','createUserName':null,'updateTime':null,'isDeleted':false}, {'id':10,'categoryType':'MIDDLE','bigCategoryName':'1.現(xiàn)場管理與保障','middleCategoryName':'1.2現(xiàn)場安全','smallCategoryName':null,'parentId':1,'createTime':'2021-07-04T11:13:36.000+0000','createUserName':null,'updateTime':null,'isDeleted':false}, {'id':3,'categoryType':'SMALL','bigCategoryName':'1.現(xiàn)場管理與保障','middleCategoryName':'1.1現(xiàn)場監(jiān)測','smallCategoryName':'1.1.1氣象監(jiān)測','parentId':2,'createTime':'2021-07-04T11:13:36.000+0000','createUserName':null,'updateTime':null,'isDeleted':false}, {'id':4,'categoryType':'SMALL','bigCategoryName':'1.現(xiàn)場管理與保障','middleCategoryName':'1.1現(xiàn)場監(jiān)測','smallCategoryName':'1.1.2地震監(jiān)測','parentId':2,'createTime':'2021-07-04T11:13:36.000+0000','createUserName':null,'updateTime':null,'isDeleted':false}, {'id':5,'categoryType':'SMALL','bigCategoryName':'1.現(xiàn)場管理與保障','middleCategoryName':'1.1現(xiàn)場監(jiān)測','smallCategoryName':'1.1.3地質(zhì)災(zāi)害監(jiān)測','parentId':2,'createTime':'2021-07-04T11:13:36.000+0000','createUserName':null,'updateTime':null,'isDeleted':false}, {'id':6,'categoryType':'SMALL','bigCategoryName':'1.現(xiàn)場管理與保障','middleCategoryName':'1.1現(xiàn)場監(jiān)測','smallCategoryName':'1.1.4水文監(jiān)測','parentId':2,'createTime':'2021-07-04T11:13:36.000+0000','createUserName':null,'updateTime':null,'isDeleted':false}, {'id':7,'categoryType':'SMALL','bigCategoryName':'1.現(xiàn)場管理與保障','middleCategoryName':'1.1現(xiàn)場監(jiān)測','smallCategoryName':'1.1.5環(huán)境監(jiān)測','parentId':2,'createTime':'2021-07-04T11:13:36.000+0000','createUserName':null,'updateTime':null,'isDeleted':false}, {'id':8,'categoryType':'SMALL','bigCategoryName':'1.現(xiàn)場管理與保障','middleCategoryName':'1.1現(xiàn)場監(jiān)測','smallCategoryName':'1.1.6疫病監(jiān)測','parentId':2,'createTime':'2021-07-04T11:13:36.000+0000','createUserName':null,'updateTime':null,'isDeleted':false}, {'id':9,'categoryType':'SMALL','bigCategoryName':'1.現(xiàn)場管理與保障','middleCategoryName':'1.1現(xiàn)場監(jiān)測','smallCategoryName':'1.1.7觀察測量','parentId':2,'createTime':'2021-07-04T11:13:36.000+0000','createUserName':null,'updateTime':null,'isDeleted':false}, {'id':11,'categoryType':'SMALL','bigCategoryName':'1.現(xiàn)場管理與保障','middleCategoryName':'1.2現(xiàn)場安全','smallCategoryName':'1.2.1現(xiàn)場照明','parentId':10,'createTime':'2021-07-04T11:13:36.000+0000','createUserName':null,'updateTime':null,'isDeleted':false}, {'id':12,'categoryType':'SMALL','bigCategoryName':'1.現(xiàn)場管理與保障','middleCategoryName':'1.2現(xiàn)場安全','smallCategoryName':'1.2.2現(xiàn)場警戒','parentId':10,'createTime':'2021-07-04T11:13:36.000+0000','createUserName':null,'updateTime':null,'isDeleted':false}, {'id':28,'categoryType':'MIDDLE','bigCategoryName':'2.生命救援與生活救助','middleCategoryName':'2.1人員安全防護','smallCategoryName':null,'parentId':27,'createTime':'2021-07-04T11:13:36.000+0000','createUserName':null,'updateTime':null,'isDeleted':false}, {'id':34,'categoryType':'MIDDLE','bigCategoryName':'2.生命救援與生活救助','middleCategoryName':'2.2生命搜救與營救','smallCategoryName':null,'parentId':27,'createTime':'2021-07-04T11:13:36.000+0000','createUserName':null,'updateTime':'2021-07-04T13:03:23.000+0000','isDeleted':false}, {'id':29,'categoryType':'SMALL','bigCategoryName':'2.生命救援與生活救助','middleCategoryName':'2.1人員安全防護','smallCategoryName':'2.1.1衛(wèi)生防疫','parentId':28,'createTime':'2021-07-04T11:13:36.000+0000','createUserName':null,'updateTime':null,'isDeleted':false}, {'id':30,'categoryType':'SMALL','bigCategoryName':'2.生命救援與生活救助','middleCategoryName':'2.1人員安全防護','smallCategoryName':'2.1.2消防防護','parentId':28,'createTime':'2021-07-04T11:13:36.000+0000','createUserName':null,'updateTime':null,'isDeleted':false}, {'id':31,'categoryType':'SMALL','bigCategoryName':'2.生命救援與生活救助','middleCategoryName':'2.1人員安全防護','smallCategoryName':'2.1.3化學(xué)與放射','parentId':28,'createTime':'2021-07-04T11:13:36.000+0000','createUserName':null,'updateTime':null,'isDeleted':false}, {'id':32,'categoryType':'SMALL','bigCategoryName':'2.生命救援與生活救助','middleCategoryName':'2.1人員安全防護','smallCategoryName':'2.1.4防高空墜落','parentId':28,'createTime':'2021-07-04T11:13:36.000+0000','createUserName':null,'updateTime':null,'isDeleted':false}, {'id':33,'categoryType':'SMALL','bigCategoryName':'2.生命救援與生活救助','middleCategoryName':'2.1人員安全防護','smallCategoryName':'2.1.5通用防護','parentId':28,'createTime':'2021-07-04T11:13:36.000+0000','createUserName':null,'updateTime':null,'isDeleted':false}, {'id':35,'categoryType':'SMALL','bigCategoryName':'2.生命救援與生活救助','middleCategoryName':'2.2生命搜救與營救','smallCategoryName':'2.2.1生命搜索','parentId':34,'createTime':'2021-07-04T11:13:36.000+0000','createUserName':null,'updateTime':null,'isDeleted':false}, {'id':36,'categoryType':'SMALL','bigCategoryName':'2.生命救援與生活救助','middleCategoryName':'2.2生命搜救與營救','smallCategoryName':'2.2.2攀巖營救','parentId':34,'createTime':'2021-07-04T11:13:36.000+0000','createUserName':null,'updateTime':null,'isDeleted':false}, {'id':37,'categoryType':'SMALL','bigCategoryName':'2.生命救援與生活救助','middleCategoryName':'2.2生命搜救與營救','smallCategoryName':'2.2.3破拆起重','parentId':34,'createTime':'2021-07-04T11:13:36.000+0000','createUserName':null,'updateTime':null,'isDeleted':false}, {'id':38,'categoryType':'SMALL','bigCategoryName':'2.生命救援與生活救助','middleCategoryName':'2.2生命搜救與營救','smallCategoryName':'2.2.4水下營救','parentId':34,'createTime':'2021-07-04T11:13:36.000+0000','createUserName':null,'updateTime':null,'isDeleted':false}, {'id':39,'categoryType':'SMALL','bigCategoryName':'2.生命救援與生活救助','middleCategoryName':'2.2生命搜救與營救','smallCategoryName':'2.2.5通用工具','parentId':34,'createTime':'2021-07-04T11:13:36.000+0000','createUserName':null,'updateTime':null,'isDeleted':false} ] }},created() { this.getSuppliesType(0)},methods: { getSuppliesType(id) {const queryData = { parentId: id}//此處為js模擬,真實數(shù)據(jù)的獲取還需要后臺接口的支持getSuppliersType(JSON.stringify(queryData)).then(response => { console.log(response) console.log(response.data[0].categoryType) //存放此次查詢結(jié)果 let tmpList = [] this.dataList.forEach((item, index) => {if(item.parentId === id){ tmpList.push(item)} }) if (tmpList[0].categoryType === ’BIG’) {this.bigTypes = tmpList } else if (response.data[0].categoryType === ’MIDDLE’) {this.middleTypes = tmpList } else {this.smallTypes = tmpList }}).catch(function (error) { console.log(error)}) }, commit() {console.log('點擊了提交按鈕') }, cancel() {this.$router.go(-1) }} }</script>

​ 又到了分隔線以下,本文到此就結(jié)束了,本文內(nèi)容全部都是由博主自己進(jìn)行整理并結(jié)合自身的理解進(jìn)行總結(jié)

到此這篇關(guān)于Vue 級聯(lián)下拉框的設(shè)計與實現(xiàn)的文章就介紹到這了,更多相關(guān)Vue 級聯(lián)下拉框 內(nèi)容請搜索好吧啦網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持好吧啦網(wǎng)!

標(biāo)簽: Vue
相關(guān)文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
亚洲天堂免费| 亚洲香蕉网站| 国产精品久久久久9999高清| 欧美日韩夜夜| 91亚洲自偷观看高清| 99久久夜色精品国产亚洲1000部| 亚洲在线成人| 国产乱人伦精品一区| 伊人久久在线| 蜜桃免费网站一区二区三区| 国产精品白浆| 婷婷精品视频| 日本成人在线不卡视频| 日韩成人a**站| 视频一区在线视频| 久久精品国产99国产| 亚洲h色精品| 亚洲1区在线观看| 久久中文在线| 美女精品网站| 亚洲啊v在线| 亚洲一级黄色| 国产精品tv| 99精品99| 精品国产亚洲一区二区三区在线 | 亚洲国产专区校园欧美| 婷婷精品在线| 亚洲精品一区三区三区在线观看| 欧美一区91| 老鸭窝一区二区久久精品| 国产一区二区三区四区五区| 国产欧美另类| 蜜桃久久久久| 亚洲天堂免费| 日本在线精品| 奇米亚洲欧美| 国产农村妇女精品一二区| 国产精品成人a在线观看| 亚洲精品婷婷| 日韩欧美一区二区三区在线视频 | 色欧美自拍视频| 亚洲无线观看| 欧美日韩免费观看视频| 欧美日本二区| 男人操女人的视频在线观看欧美| 欧美国产一级| 国产日产精品_国产精品毛片| 999久久久91| 免费看久久久| 日本91福利区| 蜜臀久久99精品久久久久久9| 日韩不卡免费高清视频| 欧美国产日本| 日韩精品亚洲一区二区三区免费| 日韩精品首页| 久久精品国产久精国产| 日韩中文av| 一区在线免费观看| 蜜桃视频在线网站| 久久只有精品| 国产丝袜一区| 亚洲另类av| 不卡视频在线| 天堂中文av在线资源库| 麻豆国产精品一区二区三区| 少妇精品久久久一区二区三区| 一区在线免费观看| 久久天堂av| 天堂8中文在线最新版在线| 国产日韩一区二区三免费高清| 中文一区一区三区免费在线观 | 日本不卡高清| 香蕉久久国产| 国户精品久久久久久久久久久不卡| 精品一区二区三区四区五区| 日韩av午夜在线观看| 亚洲网址在线观看| 久久午夜影视| 亚洲欧美成人综合| 欧美日韩精品一本二本三本| 成人午夜国产| 麻豆视频在线观看免费网站黄| 久久国产人妖系列| 日本午夜精品| 日本免费在线视频不卡一不卡二| 亚洲资源在线| 日本欧洲一区二区| 免费久久精品视频| 蜜臀91精品一区二区三区| 丝瓜av网站精品一区二区| 91精品电影| 午夜精品婷婷| 亚洲中午字幕| 中文不卡在线| 亚洲免费观看高清完整版在线观| 日韩中文字幕亚洲一区二区va在线| 在线日韩欧美| 欧美日韩激情| 国产精品极品在线观看| 日韩av中文字幕一区| 青草国产精品| 国产欧美一区二区三区米奇| 国产一级成人av| 久久不卡国产精品一区二区| 国产精品久久久亚洲一区| 国产精品一区二区免费福利视频| 国产精品久久久久77777丨| 久久亚洲精品中文字幕| 国产精品成久久久久| 久久久久久久久久久9不雅视频| 欧美日中文字幕| 午夜宅男久久久| 亚洲精品日本| 欧美在线不卡| 精品五月天堂| 日韩av首页| 99国产精品私拍| 日韩精品亚洲aⅴ在线影院| 国产精品nxnn| yellow在线观看网址| 国产一区欧美| 亚洲色图国产| 国产亚洲精品精品国产亚洲综合| 精品国产三区在线| 久久国产毛片| 亚洲综合婷婷| 精品视频网站| 91精品蜜臀一区二区三区在线| 夜夜嗨网站十八久久| 91精品国产自产观看在线| 久久99视频| 91精品推荐| 亚洲精品欧洲| 色婷婷色综合| 老鸭窝毛片一区二区三区| 国产欧美在线| 久久婷婷av| 日本免费在线视频不卡一不卡二| 精品视频自拍| 最新亚洲激情| 久久国产三级精品| 欧美sss在线视频| 亚洲一区二区三区四区五区午夜| 日韩精品视频在线看| 91视频精品| 亚洲一区二区三区中文字幕在线观看| 国产精品一区毛片| 99久久久久| 天堂久久一区| 激情黄产视频在线免费观看| 国产视频一区免费看| 国产精品三级| 黑丝一区二区三区| 久久av电影| 久久99伊人| 国产成人调教视频在线观看| 亚洲一区中文| 国产精品jk白丝蜜臀av小说| 欧美成人午夜| 国产精品毛片久久久| 在线综合亚洲| 久久精品资源| 亚洲一级大片| 日韩网站中文字幕| 国产日韩欧美在线播放不卡| 午夜影院欧美| 激情久久99| 日本中文字幕一区二区| 久久精品91| 久久不见久久见国语| 国产视频一区在线观看一区免费| 国产精品久久久久久久免费观看| 日韩三级一区| 久久免费国产| 老司机免费视频一区二区三区| 免费精品视频在线| 99久久夜色精品国产亚洲狼| 国产日产精品_国产精品毛片 | 特黄特色欧美大片| 蜜臀91精品一区二区三区| 日韩av自拍| 久久国产精品免费精品3p| 一区三区视频| 亚洲啊v在线| 国产精品尤物| 亚洲影院天堂中文av色| 亚洲午夜精品久久久久久app| 欧美啪啪一区| 视频一区二区三区在线| 欧美成人基地| 国产aⅴ精品一区二区三区久久| 日韩成人一级| 免费观看日韩电影| 日韩成人免费| 国产精品黄色片| 日韩一区二区三免费高清在线观看| 欧美高清不卡| 91一区二区| 精品三级久久久| 国产精品亚洲二区|