HTML页面使用vant控件,使用vant的地域控件追加全部选项

在 Vue 项目中,通过 vant 的 Area 插件实现了省市区选择,但原生插件未提供全选功能。通过自定义 `change` 和 `areaSelect` 方法,实现了在一级和二级选择时添加“全部”选项的功能,确保无选择时也能有默认值。文章详细介绍了改造过程,并提供了相关代码示例。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

在项目中使用了vant的Area插件,需要进行全部匹配,vant本身没有实现,需要改造代码,方法如下:

起点

终点

vue的methos中添加下面两个方法:

change(picker, value, index){

if(value[0].code != 100000){

if(index == 0){

let addr = this.areaList;

let areaListCode = value[0].code;

let code1 = Object.assign({},addr.city_list,{[areaListCode]:"全部"});

let code2 = Object.assign({},addr.county_list,{[areaListCode]:"全部"});

this.areaList.city_list = code1;

this.areaList.county_list = code2;

}

if (index == 1) {

let addr = this.areaList;

let areaListCode = value[1].code;

let code = Object.assign({},addr.county_list,{[areaListCode]: "全部"});

this.areaList.county_list = code;

}

}

},

areaSelect(type) {

let addr = this.areaList;

this.PickerType = type;

this.show = true;

if(this.PickerType == 1 && this.endAddrInfo == "请选择"){

this.$refs.area.reset();

};

let province_list = Object.assign({},addr.province_list,{100000:"全部"});

let city_list = Object.assign({},addr.city_list,{100100:"全部"});

let county_list = Object.assign({},addr.county_list ,{100101:"全部"});

this.areaList={

province_list,city_list,county_list

};

},

补充知识:使用vant中的Area 省市区选择和Area控件如果没有选中第三级的话就选不到当前值

今天要使用Area选择器在网上查了很多方法一直都无法让他隐藏再弹出来今天我就写下我的心得

效果图如下:

a45c95e946b63552107a64e03150c3c5.png

Area组件一般都是配合van-cell使用的

a91d23e6cd3a2a0499cbf6ac4c59256f.png

1,在加载页面的时候我让show为false

a586886e38fcc32d842062da8e0cd062.png

156c46b7f2e71cda52ab5711387f2fef.png

然后在点击了van-cell组件之后调用areaSelect方法把show变为true就能显示

e7fc94bec4f6c6e022450ccd9a7ef0b7.png

27770e2f27f499c2c76c8d5d3247d1fc.png

然后还有就是如要要有联动效果一定要在给个初始值,这个的作用就是你点击area控件之后弹出控件就算不选址直接点击确定也可以有默认值

47b586d89a9ffa54d1426a2a0a66ff01.png

在者就是要想取的值一定要给onChange写成这样,不然的话,如果你没有触发第三级(就是区县的话)就不会刷新就是还是上一个选中的区县的值,刚开始我是写成这样

错误的:

23cf14991e5b8ed26ec282558e9cac8b.png

正确的:

71214b1313300af3927c64b42d4379cc.png

以上这篇使用vant的地域控件追加全部选项就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持脚本之家。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值