uvui省市区三级联动uv-picker组件的使用(uview同理u-picker)

uvui和uview组件库的导入就不在这里说了,直接说uv-picker的使用

一,效果图

二,代码展示

1,html代码

<uv-form-item label="选择地址" prop="address" required @click="cityOpen">
	<uv-input v-model="modelValue.address" border="surround" 
placeholder="请选择地址" fontSize="24rpx" color="#858585">
    </uv-input>
</uv-form-item>
<uv-picker ref="pickerRef" :loading="loadingPick" keyName="name" 
:columns="cityColumns" @confirm="cityConfirm" @change="cityChange">
</uv-picker>

2.js代码

该功能的实现思路,主要是由于后端返回的数据是分开的,即省的数据先从接口获取,再根据得到的省的id去获取市的数据,然后再根据市的id去获取区的数据;每滑动一次数据就重新根据滑动到的数据id去获取新的市区数据;

const pickerRef = ref(null);

//弹出选择框
const cityOpen = () => {
	pickerRef.value.open();
}

// 获取第一列的值
const getArea = () => {
	uni.$uv.http.get('/weChat/regions/selectListByParentId', {
		params: {
			'parentId': '' //传入父id
		}
	}).then(res => {
		cityColumns.value[0] = res.data; //设置第一列的值
		getStreet(0, cityColumns.value[0][0].id); //初次渲染第二列的值
	})
}

//当选择值变化时触发
const cityChange = (e) => {
	const {
		columnIndex,
		index
	} = e
	// columnIndex === 0 代表为滑动的是第一例 === 1时为第二列
	if (columnIndex === 0) {
		getStreet(0, e.value[0].id) //获取第二列的值
	} else if (columnIndex === 1) {
		getStreet(1, e.value[1].id) //获取第三列的值
	}
}

//获取和设置二三列的值 index 为滑动的列
const getStreet = (index, id) => {
	uni.$uv.http.get('/weChat/regions/list', {
		params: {
			'parentId': id
		}
	}).then(res => {
		if (res.code == 200) {
			if (index === 0) { //设置第二列的值
				pickerRef.value.setColumnValues(1, res.data);
				cityColumns.value[1] = res.data;
				getStreet(1, cityColumns.value[1][0].id); //初次渲染第三列的值
			} else if (index === 1) { //设置第三列的值
				pickerRef.value.setColumnValues(2, res.data);
				cityColumns.value[2] = res.data;
			}
		}
	})
}

如果初次没有获取第二第三列的值会出现这样的情况

  • 11
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 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、付费专栏及课程。

余额充值