vant中的picker選擇器自定義選項內容
更新時間:2022年12月05日 10:19:55 作者:sunddy_x
這篇文章主要介紹了vant中的picker選擇器自定義選項內容,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
vant picker選擇器自定義選項內容
項目中遇到需要在選擇器中展示多行數(shù)據,這里需要用到picker的自定義選項內容。

代碼
<template>
<div class="app-container">
<van-nav-bar :title="navTitle" />
<section>
<van-form @submit="onSubmit">
<van-field
readonly
clickable
name="picker"
:value="value"
label="選擇器"
placeholder="點擊選擇"
@click="showPicker = true"
/>
<van-popup v-model="showPicker" position="bottom">
<van-picker
show-toolbar
:columns="columns"
value-key="name"
item-height="56px"
@confirm="onConfirm"
@cancel="showPicker = false"
>
<template #option="option">
<div style="display: flex; flex-direction: column; align-items: center;">
<div>姓名:{{ option.name }}</div>
<div>年齡:{{ option.age }}</div>
</div>
</template>
</van-picker>
</van-popup>
<div style="margin: 16px;">
<van-button round block type="info" native-type="submit">提交</van-button>
</div>
</van-form>
</section>
</div>
</template>
<script>
export default {
name: 'Form',
data() {
return {
navTitle: '表單',
value: '',
columns: [{
name: '張三',
age: 18
}, {
name: '李四',
age: 19
}],
showPicker: false
}
},
methods: {
onConfirm(value) {
this.value = value
this.showPicker = false
},
onSubmit(values) {
console.log('submit', values)
}
}
}
</script>
<style lang="less" scoped>
section {
padding: 20px;
}
</style>
效果圖

vant 使用picker二級級聯(lián)
其實邏輯比較簡單(話不多說上代碼)
<van-field
readonly
clickable
name="bankId"
label="機構名稱"
:value="bankIdValue"
placeholder="選擇機構"
@click="bankIdShowPicker = true"
/>
<van-popup v-model="bankIdShowPicker" round position="bottom">
<van-picker
show-toolbar
:columns="bankId_columns"
@cancel="bankIdShowPicker = false"
@confirm="bankIdShowPickerOnConfirm"
/>
</van-popup>export default {
data() {
bankIdShowPicker: false,
bankId_columns: [
{
text: "",
id: "",
children: [
{
text: "",
id: "",
},
{
text: "",
id: "",
},
],
},
],
bankIdMap: {},
}
mounted() {
console.log("mounted.........");
this.getBranchList();
},
methods: {
getBranchList() {
//此處調用的接口
this.$get("/user/findBranchId")
.then((res) => {
console.log("res.data", res.data);
if (res.data.resultCode == "0") {
this.bankId_columns[0].text = res.data.data.branchName;
var childrenBankList = res.data.data.childBranchList;
let map = new Map();
this.bankId_columns[0].children = [];
for (let i = 0; i < childrenBankList.length; i++) {
let childrenBanObject = {
text: "",
id: "",
};
childrenBanObject.text = childrenBankList[i].branchName;
childrenBanObject.id = childrenBankList[i].id;
this.bankId_columns[0].children.push(childrenBanObject);//插入數(shù)據
map.set(childrenBankList[i].branchName, childrenBankList[i].id);
}
this.bankIdMap = map;
} else {
Toast(res.data.resultDesc);
}
})
.catch((err) => {
Toast("出了點小問題");
throw err;
});
},
//選擇器確認按鈕
bankIdShowPickerOnConfirm(value) {
console.log("value", value);
console.log("children", this.bankId_columns[0].children);
this.bankIdValue = value[1];
this.childrenBankIdValue = this.bankIdMap.get(value[1]);
console.log("childrenBankIdValue", this.childrenBankIdValue);
this.bankIdShowPicker = false;
},
}

這是后臺返回數(shù)據
來看效果??!

以上為個人經驗,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關文章
基于webpack4+vue-cli3項目實現(xiàn)換膚功能
這篇文章主要介紹了基于webpack4+vue-cli3項目的換膚功能,文中是通過scss+style-loader/useable做換膚功能,本文給大家介紹的非常詳細,具有一定的參考借鑒價值,需要的朋友可以參考下2019-07-07
Vue3 去除 vue warn 及生產環(huán)境去除console.log的方法
這篇文章主要介紹了Vue3 去除 vue warn 及生產環(huán)境去除console.log的方法,本文結合實例代碼給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下2023-06-06
Vue.config.productionTip = false 不起作用的問題及解決
本文主要介紹了Vue.config.productionTip = false 不起作用的問題及解決,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2025-08-08
vue+jquery+lodash實現(xiàn)滑動時頂部懸浮固定效果
這篇文章主要為大家詳細介紹了vue+jquery+lodash實現(xiàn)滑動時頂部懸浮固定效果,具有一定的參考價值,感興趣的小伙伴們可以參考一下2018-04-04
vue-router清除url地址欄路由參數(shù)的操作代碼
這篇文章主要介紹了vue-router清除url地址欄路由參數(shù),本文給大家介紹的非常詳細,需要的朋友可以參考下2015-11-11
vue-router使用next()跳轉到指定路徑時會無限循環(huán)問題
這篇文章主要介紹了vue-router使用next()跳轉到指定路徑時會無限循環(huán)問題,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教2023-11-11

