详解element-ui级联菜单(城市三级联动菜单)和回
网络编程 2021-07-04 15:01www.168986.cn编程入门
这篇文章主要介绍了详解element-ui级联菜单(城市三级联动菜单)和回显问题,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们狼蚁网站SEO优化随着长沙网络推广来一起学习学习吧
代码最狼蚁网站SEO优化
各项的参数截图
代码如下
<el-form-item label="户籍所在地" prop="censusLand" style="padding-left:57px"> <el-cascader v-model="ruleForm.censusLand" style="width:180px;padding-left:7px;width:270px" placeholder="请选择省市区" :options="cascaderData1" @expand-change="censusLandChange" :props="{ value: 'id', label: 'name', children: 'cities' }" ></el-cascader> </el-form-item>
data (){ retutn { ruleForm: { censusLand // 双向绑定 }, cascaderData1: [], // 户籍省 一级菜单 } }
// 户籍所在地-选中后下一级 censusLandChange(val) { this.getCensusLand(val); },
// 户籍所在地 getCensusLand(val) { // console.log(val); let idArea; let sizeArea; if (!val) { idArea = null; sizeArea = 0; } else if (val.length === 1) { idArea = val[0]; sizeArea = val.length; // 3:一级 4:二级 6:三级 } else if (val.length === 2) { idArea = val[1]; sizeArea = val.length; // 3:一级 4:二级 6:三级 } this.$get( "/stu/student/getAreaId", { AreaId: idArea }, res => { // console.log("1111",res); if (sizeArea === 1) { // 点击一级 加载二级 市 this.cascaderData1.map((value, i) => { if (value.id === val[0]) { if (!value.cities.length) { value.cities = res.data.map((value, i) => { return { id: value.id, name: value.name, cities: [] }; }); } } }); } else if (sizeArea === 2) { // 点击二级 加载三级 区 this.cascaderData1.map((value, i) => { if (value.id === val[0]) { value.cities.map((value, i) => { if (value.id === val[1]) { if (!value.cities.length) { value.cities = res.data.map((value, i) => { return { id: value.id, name: value.name }; }); } } }); } }); } // console.log(this.ruleForm.censusLand); }, err => {} ); },
回显时,注意要同步(通过new Promise)
this.getAllMe(); // 先获取一级的城市
// 在回显数据的res 里放入这段代码(视情况而定) // 需要先加载市级菜单,再去加载省级的() // 户口所在地 new Promise((resolve, reject) => { let val = [res.data.getupdate.domicileProvinceId]; let idArea; let sizeArea; if (!val) { idArea = null; sizeArea = 0; } else if (val.length === 1) { idArea = val[0]; sizeArea = val.length; // 3:一级 4:二级 6:三级 } this.$get( "/stu/student/getAreaId", { AreaId: idArea }, res => { // console.log("1111", res); if (sizeArea === 1) { // 点击一级 加载二级 市 this.cascaderData1.map((value, i) => { if (value.id === val[0]) { if (!value.cities.length) { value.cities = res.data.map((value, i) => { return { id: value.id, name: value.name, cities: [] }; }); } } }); } resolve(res); }, err => { reject(err); } ); }) .then(data => { // 通过他们去获取第三级的 this.getCensusLand([ res.data.getupdate.domicileProvinceId, // 一级 res.data.getupdate.domicileCityId // 二级 ]); // 户口所在地 }) .catch(err => { console.log(err); });
最后再双向绑定给censusLand
// 户籍 censusLand: [ res.data.getupdate.domicileProvinceId * 1, res.data.getupdate.domicileCityId * 1, res.data.getupdate.domicileDistrictId * 1 ],
大概就这些了,希望对大家有帮助。也希望大家多多支持狼蚁SEO。
编程语言
- 机械手焊接机器人编程 机械手焊接设备编程
- vb数据库编程实例,vb做数据库
- tiobe世界编程语言排行榜,全球编程语言排行
- 成都java编程培训 成都it编程培训中心
- 编程基础培训,编程基础知识培训
- flash游戏编程基础教程,flash游戏开发教程
- 不会英语能学编程吗 不会英语可以学程序员吗
- 爱心代码编程C语言 爱心代码编程c语言公式
- c语言编程学习入门 c语言编程快速入门
- 西门子plc编程培训 西门子plc编程培训班
- 哪里可以学编程 台州哪里可以学编程
- 少儿编程哪个好 少儿编程哪个品牌好
- 编程是什么意思,图形编程是什么意思
- c语言编程软件下载,c语言编程软件在哪下载
- java编程软件下载,java编程下载手机版
- ug编程培训学校,ug编程培训教程