成人在线亚洲_国产日韩视频一区二区三区_久久久国产精品_99国内精品久久久久久久

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

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

瀏覽:35日期: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
相關文章:
成人在线亚洲_国产日韩视频一区二区三区_久久久国产精品_99国内精品久久久久久久
中文字幕第一区二区| 激情综合电影网| 午夜欧美精品| 欧美日韩成人综合在线一区二区| 亚洲第一狼人社区| 亚洲免费播放| 国产精品传媒入口麻豆| 欧美欧美全黄| 久久精品一区二区三区不卡| 成人性生交大片免费看在线播放| 91精品免费观看| 国产一区二区三区香蕉| 欧美影院精品一区| 亚洲一区在线观看视频| 在线免费高清一区二区三区| 中文字幕欧美日韩一区| 欧美日韩国产高清| 中文字幕免费在线观看视频一区| 99精品欧美一区二区蜜桃免费 | 亚洲第一会所有码转帖| 国产欧美日韩综合一区在线播放| 亚洲一区日韩精品中文字幕| 国产精品亚洲综合久久| 午夜精品一区二区三区三上悠亚| 久久三级视频| 天堂精品中文字幕在线| 色噜噜狠狠色综合中国| 美女网站一区二区| 欧美日韩在线观看一区二区| 国产最新精品免费| 日韩一区二区三区三四区视频在线观看| 国产精品白丝jk白祙喷水网站| 欧美一区二区日韩一区二区| 99九九99九九九视频精品| 久久精品人人做人人综合| 欧美日韩国产三区| 伊人一区二区三区| 麻豆av福利av久久av| 免费观看成人鲁鲁鲁鲁鲁视频| 欧美日韩一区二区三区高清| 国产剧情一区在线| 久久综合色婷婷| 欧美日韩国产精品一卡| 成人欧美一区二区三区| 亚洲欧美日本日韩| 麻豆一区二区三区| 日韩欧美一区电影| 欧美成人免费在线| 亚洲国产成人tv| 欧美精品日韩一本| 91蜜桃免费观看视频| 亚洲日穴在线视频| 欧美影视一区二区三区| 成人午夜激情在线| 亚洲手机成人高清视频| 久久久久综合| 国产v综合v亚洲欧| 中文字幕av资源一区| 国产精品一区亚洲| 国产精品自拍网站| 国产婷婷一区二区| 国产欧美日韩综合一区在线播放| 日韩中文字幕1| 欧美成人官网二区| 一本色道88久久加勒比精品| 久久精品国产亚洲a| 26uuu久久天堂性欧美| 亚洲精品极品| 久久爱www久久做| 国产欧美一区二区精品仙草咪| 一本色道久久综合亚洲二区三区| 久久99九九99精品| 中文幕一区二区三区久久蜜桃| 国产一区二区三区高清| 国内精品第一页| 国产精品久久久久久久久晋中| 蜜桃av一区| 高清日韩电视剧大全免费| 中文字幕在线观看不卡视频| 一本久久综合亚洲鲁鲁五月天| 成人涩涩免费视频| 一区二区国产视频| 日韩一级黄色大片| 国产欧美成人| 东方aⅴ免费观看久久av| 日韩毛片精品高清免费| 欧美亚州韩日在线看免费版国语版| av网站免费线看精品| 亚洲国产乱码最新视频 | 欧美精品自拍偷拍| 亚洲无线一线二线三线区别av| 美女视频黄频大全不卡视频在线播放| 亚洲精品一区二区精华| 久久精品一区二区国产| 91论坛在线播放| 日本不卡一二三| 欧美—级在线免费片| 在线一区二区观看| 国内久久视频| 国产一区二区三区香蕉| 亚洲视频一二三区| 日韩免费福利电影在线观看| 国产日韩欧美一区二区三区四区| 丁香一区二区三区| 偷拍一区二区三区四区| 国产亚洲福利社区一区| 欧美午夜精品久久久久久孕妇| 国产精品大片| 精品一区二区三区av| 亚洲欧洲日韩综合一区二区| 欧美日韩一二三| 亚洲精品欧洲| 成人黄色在线网站| 麻豆精品在线看| 亚洲欧美电影一区二区| 欧美成人a视频| 欧美自拍偷拍午夜视频| 最新国产拍偷乱拍精品| 丁香六月久久综合狠狠色| 日韩精品亚洲一区| 国产精品久久久久一区| 欧美一区二区精品在线| 欧美中日韩免费视频| 欧美精品首页| 国产成人免费在线观看不卡| 亚洲成人免费在线观看| 中文字幕欧美国产| 日韩精品一区国产麻豆| 日本韩国视频一区二区| 国产区欧美区日韩区| 欧美日韩综合| 成人免费视频视频在线观看免费 | 日韩av午夜在线观看| 成人免费在线播放视频| 日韩精品一区二区三区三区免费 | 91精品国模一区二区三区| 久久久久国内| 日韩一级免费| 亚洲性感激情| av亚洲精华国产精华精华| 九九精品一区二区| 天天操天天综合网| 亚洲午夜久久久久久久久电影网| 国产精品国产自产拍在线| 久久久一区二区三区捆绑**| 91精品国产色综合久久不卡电影 | 久久中文娱乐网| 欧美日韩国产一二三| 羞羞答答国产精品www一本| 黑人一区二区| 欧美 日韩 国产在线| 成人性生交大合| 国产精选一区二区三区| 久久97超碰色| 男女男精品网站| 天堂成人国产精品一区| 亚洲主播在线播放| 亚洲综合在线免费观看| 亚洲女子a中天字幕| 综合分类小说区另类春色亚洲小说欧美| 久久综合色婷婷| 日韩欧美一卡二卡| 777奇米四色成人影色区| 欧美日韩黄色一区二区| 欧美视频一区二区在线观看| 色婷婷精品久久二区二区蜜臂av | 日韩一二三区不卡| 91精品啪在线观看国产60岁| 在线电影一区二区三区| 欧美精品日韩精品| 欧美精品18+| 91精品啪在线观看国产60岁| 欧美剧在线免费观看网站| 精品视频一区 二区 三区| 欧美午夜影院一区| 欧美日韩国产中文| 欧美日韩国产成人在线免费| 欧美日韩一区二区在线视频| 欧美日韩日日摸| 337p亚洲精品色噜噜| 欧美美女bb生活片| 777久久久精品| 欧美一区二区三区视频在线| 91精品啪在线观看国产60岁| 日韩一区二区三区观看| 欧美成人精品福利| 久久久综合视频| 欧美激情自拍偷拍| 国产精品色在线| 综合中文字幕亚洲| 玉足女爽爽91| 亚洲一级二级在线| 日韩一区欧美二区| 久久99蜜桃精品| 国产盗摄精品一区二区三区在线| 国产成人av电影在线播放| 波多野结衣中文字幕一区| 色综合久久综合网| 激情综合激情| 午夜亚洲一区|