uni-app中的城市三级联动

52 篇文章 2 订阅

第一步,我们在uniapp中引入插件

import mpvueCityPicker from '@/components/uni-ui/mpvue-citypicker/mpvueCityPicker.vue';

第二步,注册插件

components:{
			mpvueCityPicker,
		},

第三步,将view中的标签写入

<mpvue-city-picker :themeColor="themeColor" ref="mpvueCityPicker" :pickerValueDefault="cityPickerValueDefult" @onCancel="onCancel" @onConfirm="onConfirm"></mpvue-city-picker>

第四步,将所需要的的变量写在data中

data() {
			return {
				themeColor:'#007AFF',
				cityPickerValueDefult:[0,0,1],
				pickerText:'',
                
			}
		},

第五步,将绑定的事件写上

// 三级联动提交
			onConfirm(e){
				this.pickerText = e.label;
			},

第六步,将开关绑定到需要的组件上

<uni-list-item title="家乡" :rightText="pickerText" @click="showCityPicker"></uni-list-item>

第七步:来吧,展示(绑定事件展示组件)

showCityPicker(){
				this.$refs.mpvueCityPicker.show();
			},

第八步:关闭或者返回的时候卸载组件

        // 监听返回
		onBackPress() {
			if(this.$refs.mpvueCityPicker.showPicker){
				this.$refs.mpvueCityPicker.pickerCancel();
				return true;
			}
		},// 监听页面卸载
		onUnload() {
			if(this.$refs.mpvueCityPicker.showPicker){
				this.$refs.mpvueCityPicker.pickerCancel()
			}
			if(this.$refs.mpvueCityPicker.showPicker){
				this.$refs.mpvueCityPicker.pickerCancel()
			}
		},

 

Uniapp实现地址三级联动,可以使用uni-simple-router插件结合van-picker组件来实现。以下是一个简单的示例: 1. 首先,安装uni-simple-router和van-picker插件: ```bash npm install uni-simple-router npm install vant ``` 2. 创建一个router.js文件,并配置路由: ```javascript import Vue from 'vue'; import Router from 'uni-simple-router'; Vue.use(Router); const router = new Router({ routes: [ // ...其他路由配置 { path: '/address', name: 'address', component: () => import('@/pages/Address.vue') } ] }); export default router; ``` 3. 在main.js文件引入router.js,并注册路由: ```javascript import Vue from 'vue'; import App from './App'; import router from './router'; Vue.config.productionTip = false; App.mpType = 'app'; const app = new Vue({ ...App, router }); app.$mount(); ``` 4. 创建一个Address.vue组件,用于显示地址选择器: ```vue <template> <view> <van-picker title="选择地址" :columns="columns" @change="onChange" ></van-picker> </view> </template> <script> export default { data() { return { columns: [ // 省份数据 { values: ['北京', '上海', '广东'], defaultIndex: 0 }, // 城市数据 { values: ['北京市', '上海市', '广州市'], defaultIndex: 0 }, // 区域数据 { values: ['东城区', '徐汇区', '天河区'], defaultIndex: 0 } ] }; }, methods: { onChange(event) { console.log(event.detail); } } }; </script> ``` 在以上示例,我们使用了van-picker组件来实现地址三级联动,通过columns属性来设置省份、城市和区域的数据。在onChange方法,可以获取用户选择的地址信息。 通过以上步骤,你可以在Uniapp实现地址三级联动的功能。当然,你可以根据实际需求进行修改和扩展。
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

2019ab

你的鼓励就是我的动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值