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

您的位置:首頁技術文章
文章詳情頁

Vue 級聯下拉框的設計與實現

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

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

1.數據庫設計

​ 所有的相關數據皆可存在一張表中,這樣數據就可以不受層級的限制。

​ 表結構可以參考如下建表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 ’創建人用戶名’, `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;

數據庫截圖如下圖所示,注:本系統為了減少查詢次數,故冗余了一些字段,讀者可根據自己的需求調整。

Vue 級聯下拉框的設計與實現

核心設計在于parent_id,根據parent_id字段即可查詢到子類,結果如下圖所示:

Vue 級聯下拉框的設計與實現

Vue 級聯下拉框的設計與實現

2.前端頁面

​ 前端頁面效果如下:

Vue 級聯下拉框的設計與實現

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數據為后端從數據庫中查詢出來的數據(駝峰命名),后端只負責查詢、并返回結果。

Vue中數據定義如下:

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 } //此處的調用后端接口按照自己的調用方式寫即可 //此處的getSuppliersType是項目中自己封裝的util中的方法 //如果請求方式是post,JSON.stringify(queryData) //如果請求方式是get,queryData getSuppliersType(JSON.stringify(queryData)).then(response => { console.log(response) console.log(response.data[0].categoryType) //根據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

​ 下面這個頁面為完成代碼,其中的數據為部分數據,后臺接口獲取使用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.現場管理與保障','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.現場管理與保障','middleCategoryName':'1.1現場監測','smallCategoryName':null,'parentId':1,'createTime':'2021-07-04T11:13:36.000+0000','createUserName':null,'updateTime':null,'isDeleted':false}, {'id':10,'categoryType':'MIDDLE','bigCategoryName':'1.現場管理與保障','middleCategoryName':'1.2現場安全','smallCategoryName':null,'parentId':1,'createTime':'2021-07-04T11:13:36.000+0000','createUserName':null,'updateTime':null,'isDeleted':false}, {'id':3,'categoryType':'SMALL','bigCategoryName':'1.現場管理與保障','middleCategoryName':'1.1現場監測','smallCategoryName':'1.1.1氣象監測','parentId':2,'createTime':'2021-07-04T11:13:36.000+0000','createUserName':null,'updateTime':null,'isDeleted':false}, {'id':4,'categoryType':'SMALL','bigCategoryName':'1.現場管理與保障','middleCategoryName':'1.1現場監測','smallCategoryName':'1.1.2地震監測','parentId':2,'createTime':'2021-07-04T11:13:36.000+0000','createUserName':null,'updateTime':null,'isDeleted':false}, {'id':5,'categoryType':'SMALL','bigCategoryName':'1.現場管理與保障','middleCategoryName':'1.1現場監測','smallCategoryName':'1.1.3地質災害監測','parentId':2,'createTime':'2021-07-04T11:13:36.000+0000','createUserName':null,'updateTime':null,'isDeleted':false}, {'id':6,'categoryType':'SMALL','bigCategoryName':'1.現場管理與保障','middleCategoryName':'1.1現場監測','smallCategoryName':'1.1.4水文監測','parentId':2,'createTime':'2021-07-04T11:13:36.000+0000','createUserName':null,'updateTime':null,'isDeleted':false}, {'id':7,'categoryType':'SMALL','bigCategoryName':'1.現場管理與保障','middleCategoryName':'1.1現場監測','smallCategoryName':'1.1.5環境監測','parentId':2,'createTime':'2021-07-04T11:13:36.000+0000','createUserName':null,'updateTime':null,'isDeleted':false}, {'id':8,'categoryType':'SMALL','bigCategoryName':'1.現場管理與保障','middleCategoryName':'1.1現場監測','smallCategoryName':'1.1.6疫病監測','parentId':2,'createTime':'2021-07-04T11:13:36.000+0000','createUserName':null,'updateTime':null,'isDeleted':false}, {'id':9,'categoryType':'SMALL','bigCategoryName':'1.現場管理與保障','middleCategoryName':'1.1現場監測','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.現場管理與保障','middleCategoryName':'1.2現場安全','smallCategoryName':'1.2.1現場照明','parentId':10,'createTime':'2021-07-04T11:13:36.000+0000','createUserName':null,'updateTime':null,'isDeleted':false}, {'id':12,'categoryType':'SMALL','bigCategoryName':'1.現場管理與保障','middleCategoryName':'1.2現場安全','smallCategoryName':'1.2.2現場警戒','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衛生防疫','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化學與放射','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模擬,真實數據的獲取還需要后臺接口的支持getSuppliersType(JSON.stringify(queryData)).then(response => { console.log(response) console.log(response.data[0].categoryType) //存放此次查詢結果 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>

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

到此這篇關于Vue 級聯下拉框的設計與實現的文章就介紹到這了,更多相關Vue 級聯下拉框 內容請搜索好吧啦網以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持好吧啦網!

標簽: Vue
相關文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
国产成人免费| 国产精品入口久久| 在线看片国产福利你懂的| 精品国产亚洲日本| 精品久久精品| 国内精品伊人| 国产一区二区三区天码| 久草免费在线视频| 久久久久蜜桃| 一区在线视频观看| 免费人成精品欧美精品| 视频一区国产视频| 日韩精品久久久久久| 国产图片一区| 麻豆精品久久久| 在线手机中文字幕| 国产一区日韩欧美| 四虎精品一区二区免费| 日韩黄色在线观看| 久久97视频| 日韩精品免费一区二区三区| 好看不卡的中文字幕| 蜜桃一区二区三区在线| 国产剧情一区| 五月激情久久| 蜜桃一区二区三区在线观看| 欧美一级二区| 美女一区网站| 在线视频精品| 日本免费在线视频不卡一不卡二| 久久麻豆视频| av一区二区高清| 亚洲精品乱码久久久久久蜜桃麻豆| 国产欧美另类| 国产综合色区在线观看| 黄色av一区| 日本三级亚洲精品| 国产网站在线| 国产亚洲激情| 国产精品红桃| 国产精品88久久久久久| 亚洲精品精选| 高清一区二区| 日韩制服丝袜av| 精品久久久网| 天堂av在线一区| 开心激情综合| 国产亚洲一级| 欧美交a欧美精品喷水| 久久久久久久久久久妇女| 亚洲精品无吗| 日韩欧美一区二区三区免费观看| 亚洲精选av| 国产不卡人人| 视频一区日韩精品| 日韩一区三区| 日韩国产在线不卡视频| 亚洲精品永久免费视频| 亚洲精品乱码| 色网在线免费观看| 日韩黄色av| 色婷婷狠狠五月综合天色拍| 日韩黄色在线观看| 91精品福利| 精品一区二区三区免费看| 国产午夜精品一区二区三区欧美| 久久精品国产网站| 蜜臀久久99精品久久久画质超高清| 四虎国产精品免费观看| 日韩在线观看中文字幕| 伊人精品一区| 69堂免费精品视频在线播放| 日韩欧美在线中字| 91久久精品无嫩草影院| 亚洲女同中文字幕| 久久精品系列| 涩涩涩久久久成人精品| 久久高清精品| 久久亚洲道色| 日韩精品a在线观看91| 在线视频亚洲| 日韩欧美视频专区| 里番精品3d一二三区| 日韩精品91亚洲二区在线观看| 欧美另类专区| 婷婷激情一区| 久久不卡国产精品一区二区| 蜜臀av在线播放一区二区三区| 88xx成人免费观看视频库| 国产精品s色| 日韩欧美在线精品| 久热精品在线| 妖精视频成人观看www| 亚洲91久久| 神马午夜在线视频| 九九99久久精品在免费线bt| 日韩va欧美va亚洲va久久| 男女精品网站| 国产一区观看| 99精品视频在线| 色一区二区三区四区| 国产精品免费大片| 日本少妇一区二区| 日韩精品一页| 亚洲精品亚洲人成在线观看| 国产精品呻吟| 精品日韩毛片| 国产在线不卡| 久久精品99久久无色码中文字幕| 国产一区二区三区不卡av| 国产伦一区二区三区| 日韩精品一区二区三区中文| 蜜桃视频在线观看一区| 视频一区二区中文字幕| 亚洲免费精品| 91精品一区二区三区综合在线爱| 日本欧美国产| 精品五月天堂| 久久精品毛片| 国产成人久久精品麻豆二区| 毛片不卡一区二区| 麻豆精品久久久| 精品久久久网| 成人精品视频| 日韩国产网站| 91精品婷婷色在线观看| 在线日韩av| 午夜国产精品视频免费体验区| 1024精品一区二区三区| 亚洲午夜久久久久久尤物 | 视频精品一区| 97久久精品| 国产精品网址| 免费亚洲婷婷| 高清av一区| 韩国三级一区| 女主播福利一区| 在线精品福利| 日韩二区在线观看| 老司机精品视频网| 三级在线看中文字幕完整版| 久久在线视频免费观看| 尹人成人综合网| 综合在线一区| 欧美精品福利| 久久久久观看| 韩国精品主播一区二区在线观看 | 国产精品一区2区3区| 久久精品亚洲| 亚洲精品一区三区三区在线观看| 欧美日韩国产一区精品一区| 视频一区二区国产| 国产精品亚洲综合久久| 成人污污视频| 在线一区欧美| 91精品国产自产在线丝袜啪| 免费精品一区| 婷婷成人综合| 亚洲精品九九| 国产aⅴ精品一区二区三区久久| 香蕉视频亚洲一级| 视频一区二区三区入口| 国产精品久久久久毛片大屁完整版| 成人在线视频免费| 国产精品99免费看| 日韩av中文字幕一区二区三区| 久久精品伊人| 久久av网站| 精品五月天堂| 日韩一级欧洲| 青青青国产精品| 日韩av黄色在线| 精品淫伦v久久水蜜桃| 韩日一区二区三区| 欧美亚洲免费| 欧美搞黄网站| 国产毛片一区二区三区| 2023国产精品久久久精品双| 久久精品人人| 国产伦乱精品| 日韩中文影院| 红桃视频欧美| 国产欧美成人| 久久在线视频免费观看| 日韩1区2区3区| 精品国产免费人成网站| 蜜桃成人av| 国产日本精品| 亚洲午夜精品久久久久久app| 久久国产中文字幕| 久久99视频| 久久视频一区| 欧美日韩亚洲一区二区三区在线| 日韩在线观看| 国产调教精品| 午夜国产欧美理论在线播放| 欧美精品1区| 久热re这里精品视频在线6| 国产成年精品| 日本欧美在线看|