記錄是為了更好的成長!
在項目中使用了vant的Area插件,需要進行全部匹配,vant本身沒有實現,需要改造代碼,方法如下:
<div class="site"> <span class>起點</span> <van-cell v-model="start" @click="areaSelect(0)"></van-cell> </div> <div class="site"> <span>終點</span> <van-cell v-model="end" @click="areaSelect(1)"></van-cell> </div> <van-popup v-model="show" position="bottom"> <van-area :area-list="areaList" @cancel="onCancel" @confirm="onConfirm" @change="change" ref="area" /> </van-popup>
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 }; },
以上內容代表個人觀點,僅供參考,不喜勿噴。。。
