vue基于mint-ui实现城市选择三级联动
2018-04-04 13:08
2675 查看
项目是基于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 的四级联动)
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。
您可能感兴趣的文章:
相关文章推荐
- vue基于mint-ui的城市选择3级联动的示例
- 用Vue.js来实现城市三级联动
- wheel自定义控件,实现城市三级联动,时间选择的功能简单使用
- 基于 Vue.js 的移动端组件库mint-ui实现无限滚动加载更多
- 在ASP.NET MVC中实现一种不同于平常的三级联动、级联方式, 可用于城市、车型选择等多层级联场景
- vue用mint-ui的picker组件封装一个省市区三级联动组件
- 高仿iOS 滚轮实现 省市区 城市选择三级联动
- 使用mint-ui实现省市区三级联动效果
- vue+mint ui+省市区三级联动(编辑地址)
- 高仿iOS 滚轮实现 省市区 城市选择三级联动,无需自己配置省市区域的数据
- 手把手教你webpack+vue+amaze-vue实现省市区三级联动选择组件
- js实现全国三级城市联动select选择
- vue基于element-ui的三级CheckBox复选框功能的实现代码
- wheel自定义控件,实现城市三级联动,时间选择的功能简单使用
- [置顶] 用Vue、element-ui、axios实现省市区三级联动
- 基于Bootstrap实现城市三级联动
- 基于Jquery实现省份、城市、区县三级联动
- 基于Jquery实现省份、城市、区县三级联动
- 使用mint-ui实现省市区三级联动效果的示例代码
- vue-cli结合Element-ui基于cropper.js封装vue实现图片裁剪组件功能