vue基于mint-ui实现城市选择 * 联动
作者:xilong 时间:2024-06-05 09:17:45
项目是基于vue2 的移动端项目,供大家参考,具体内容如下
1、实际效果
地址 * 联动 mint-ui picker.png
2、首先你需要去下载一个包含中国省份,城市,区县的数据
如下:
(这个地址里面包含二级联动数据, * 联动数据,四级联动数据等,找到自己需要的)
(一个更好的中国地区数据,推荐用这个)
3、具体代码
主要是用到了mint-ui的picker组件,关于mint-ui的使用就自行看官网
Ⅰ、html组件
<div>
<mt-picker :slots="myAddressSlots" @change="onMyAddressChange"></mt-picker>
<p>地址3级联动:{{myAddressProvince}} {{myAddressCity}} {{myAddresscounty}}</p>
</div>
Ⅱ、组件方法
<script>
import { Picker } from 'mint-ui';
import myaddress from '../../../static/address3.json' //引入省市区数据
export default {
name: '',
components: {
'mt-picker': Picker
},
props: {},
data () {
return {
myAddressSlots: [
{
flex: 1,
defaultIndex: 1,
values: Object.keys(myaddress), //省份数组
className: 'slot1',
textAlign: 'center'
}, {
divider: true,
content: '-',
className: 'slot2'
}, {
flex: 1,
values: [],
className: 'slot3',
textAlign: 'center'
},
{
divider: true,
content: '-',
className: 'slot4'
},
{
flex: 1,
values: [],
className: 'slot5',
textAlign: 'center'
}
],
myAddressProvince:'省',
myAddressCity:'市',
myAddresscounty:'区/县',
}
},
created() {
},
methods: {
onMyAddressChange(picker, values) {
if(myaddress[values[0]]){ //这个判断类似于v-if的效果(可以不加,但是vue会报错,很不爽)
picker.setSlotValues(1,Object.keys(myaddress[values[0]])); // Object.keys()会返回一个数组,当前省的数组
picker.setSlotValues(2,myaddress[values[0]][values[1]]); // 区/县数据就是一个数组
this.myAddressProvince = values[0];
this.myAddressCity = values[1];
this.myAddresscounty = values[2];
}
},
},
mounted(){
this.$nextTick(() => { //vue里面全部加载好了再执行的函数 (类似于setTimeout)
this.myAddressSlots[0].defaultIndex = 0
// 这里的值需要和 data里面 defaultIndex 的值不一样才能够初始化
//因为我没有看过源码(我猜测是因为数据没有改变,不会触发更新)
});
}
}
</script>
参考文章 vue mint-ui 实现省市区街道4级联动(mint-ui picker 的四级联动)
来源:https://www.jianshu.com/p/cdd3b4c1e6b5
标签:vue,mint,ui, , 联动
![](/images/zang.png)
![](/images/jiucuo.png)
猜你喜欢
python多任务之协程的使用详解
2023-12-29 16:38:23
解析JavaScript中的标签语句
2024-05-13 10:35:07
Python包管理工具pip的15 个使用小技巧
2023-08-30 17:30:51
![](https://img.aspxhome.com/file/2023/4/62594_0s.png)
详解基于pycharm的requests库使用教程
2023-08-12 09:40:39
![](https://img.aspxhome.com/file/2023/0/64740_0s.jpg)
免费开源百度编辑器(UEditor)使用方法
2023-06-01 18:05:08
![](https://img.aspxhome.com/file/2023/8/70618_0s.jpg)
Javascript typeof 用法
2013-10-20 20:49:40
如何利用JS将手机号中间四位变成*号
2024-02-23 20:07:51
sqlserver 修改列名及表名的sql语句
2024-01-18 18:32:09
如何才能有效对抗MySQL数据库的解密高手
2009-05-22 18:21:00
Vue watch原理源码层深入讲解
2024-04-30 10:40:58
![](https://img.aspxhome.com/file/2023/3/130093_0s.png)
一文搞懂Go语言操作Redis的方法
2024-04-25 13:20:25
go语言实现二叉树的序例化与反序列化
2024-04-26 17:27:30
![](https://img.aspxhome.com/file/2023/2/134082_0s.webp)
CSS样式表中SPAN和DIV的区别
2007-10-21 08:47:00
![](https://img.aspxhome.com/file/UploadPic/200710/21/2007102185219219s.jpg)
MYSQL导入导出sql文件简析
2024-01-20 15:07:15
PHP开发中常见的安全问题详解和解决方法(如Sql注入、CSRF、Xss、CC等)
2023-10-02 23:03:06
python版飞机大战代码分享
2023-11-13 22:29:03
Python进程通信之匿名管道实例讲解
2021-08-26 16:23:46
python的等深分箱实例
2022-11-30 01:01:20
![](https://img.aspxhome.com/file/2023/2/128532_0s.jpg)
github配置使用指南
2022-01-05 23:14:49
Python中遍历列表的方法总结
2023-11-01 19:11:11