uviewplus组件库中的u-picker省市区的联级选择器

npm i element-china-area-data  //获取中国的省市区

<template>
	<u-picker ref="uPickerRef" :show="show" :mode="3" :loading="loading" :columns="columns" @change="onChange"
		@confirm='confirm'></u-picker>
</template>

<script setup>
	import {
		ref,
	} from 'vue';
	import {
		onLoad,
	} from '@dcloudio/uni-app';
	//  npm i element-china-area-data  //获取中国的省市区
	import {
		regionData
	} from 'element-china-area-data';
	const loading = ref(false);
	const province = ref([]) //省
	const city = ref([]) //市
	const cityAll = ref([]) //所有市
	const area = ref([]) //区
	onLoad(() => {
		console.log(regionData);
		regionData.forEach(item => {
			province.value = [...province.value, item.label]
			item.children.forEach(val => {
				if (val.value == '1101') {
					val.children.forEach(e => {
						area.value = [...area.value, e.label]
					})
				}
				cityAll.value = [...cityAll.value, val]
			})
		})
		columns.value[0] = province.value
		columns.value[2] = area.value
	});
	const show = ref(true);
	const columns = ref([
		[],
		['市辖区'],
		[]
		// ['东城区', '西城区', '朝阳区', '丰台区', '石景山区', '海淀区', '门头沟区', '房山区', '通州区'],
	])
	const uPickerRef = ref(null)
	const onChange = (e) => {
		city.value = []
		if (e.columnIndex == 0) {
			uPickerRef.value.setColumnValues(1, []);
			loading.value = true
			columns.value[2] = []
			area.value = []
			setTimeout(() => {
				// 四个直辖市需要单独判断(重庆除外)
				if (e.value[0] == '北京市') {
					columns.value[2] = []
					columns.value[1] = ['市辖区']
					regionData[0].children[0].children.forEach(item => {
						columns.value[2].push(item.label)
					})
				} else if (e.value[0] == '天津市') {
					columns.value[2] = []
					columns.value[1] = ['市辖区']
					regionData[1].children[0].children.forEach(item => {
						columns.value[2].push(item.label)
					})
				} else if (e.value[0] == '上海市') {
					columns.value[2] = []
					columns.value[1] = ['市辖区']
					regionData[10].children[0].children.forEach(item => {
						columns.value[2].push(item.label)
					})
				} else {
					columns.value[2] = []
					regionData.forEach(item => {
						if (item.label == e.value[0]) {
							item.children.forEach(val => {
								val.children.forEach(e => {
									columns.value[2].push(e.label)
								})
								city.value = [...city.value, val.label]
							})
							columns.value[1] = city.value
						}
					})
				}
				loading.value = false
			}, 1000)
		} else if (e.columnIndex == 1) {
			uPickerRef.value.setColumnValues(2, []);
			loading.value = true
			area.value = []
			setTimeout(() => {
				cityAll.value.forEach(item => {
					if (item.label == e.value[1]) {
						item.children.forEach(val => {
							area.value = [...area.value, val.label]
						})
						columns.value[2] = area.value
					}
				})
				loading.value = false
			}, 1000)
		}
	}
	const confirm = (e) => {
		console.log('选中的值', e.value);
	}
</script>
  • 5
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
uview的u-picker组件可以实现省市区三级联动,使用时需要设置相应的数据源。以下是一个简单的例子: ```html <template> <view> <u-picker :picker-data="pickerData" :default-value="defaultValue" @change="onChange" /> </view> </template> <script> export default { data() { return { pickerData: [], defaultValue: [], }; }, mounted() { // 获取省市区数据 this.getAreaData(); }, methods: { async getAreaData() { // 发送请求获取省市区数据 const res = await this.$http.get('/api/area'); // 处理数据,将数据转换为u-picker可用的格式 this.pickerData = [ { label: '请选择', value: '', children: res.data.map((province) => ({ label: province.name, value: province.id, children: province.cities.map((city) => ({ label: city.name, value: city.id, children: city.areas.map((area) => ({ label: area.name, value: area.id, })), })), })), }, ]; // 设置默认值为当前所在地区 this.setDefaultArea(); }, setDefaultArea() { // 获取当前所在地区,将其设置为默认值 const area = this.$store.state.area; if (area.province && area.city && area.area) { this.defaultValue = [area.province.id, area.city.id, area.area.id]; } }, onChange(value) { // 处理选中的值 console.log(value); }, }, }; </script> ``` 在上面的代码中,我们使用了u-picker组件,并将picker-data设置为一个数组,数组中包含省市区三级数据。defaultValue设置为一个数组,数组中包含当前所在地区的id,这样在渲染u-picker时,就会自动选中对应的省市区。当用户选择省市区时,会触发onChange事件,我们可以在这里处理用户选择的省市区数据。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值