vant picker+popup 自定義三級(jí)聯(lián)動(dòng)案例
picker選擇器的數(shù)據(jù)由columns屬性控制,columns中有幾個(gè)元素就代表該選擇器有多少級(jí),通過change方法來給對(duì)應(yīng)列賦值。
columns = [{
values: column1, // 對(duì)應(yīng)列的值
defaultIndex: 0, // 默認(rèn)選中項(xiàng)索引
className: 'class1' // 對(duì)應(yīng)列的類名
},
{
values: [],
defaultIndex: 0,
className: 'class2'
},
{
values: [],
defaultIndex: 0,
className: 'class3'
}
];
demo
<template>
<div class="form">
<van-row type="flex" justify="center" align="center" style="padding-top:10px">
<van-col span="5" class="text">自定義三級(jí)聯(lián)動(dòng)</van-col>
<van-col span="19">
<van-field v-model="student" placeholder="請(qǐng)選擇" @click="stuShow = true" :readonly="true" />
</van-col>
</van-row>
<!-- 底部彈出 -->
<van-popup v-model="stuShow" position="bottom" :style="{ height: '40%' }">
<van-picker :columns="stuLoad" @confirm="stuConfirm" @change="stuChange" @cancel="stuShow = false" show-toolbar />
</van-popup>
</div>
</template>
<script>
export default {
name: "Form",
data() {
return {
student: '',
stuShow: false,
stuLoad: [],
stuColumn1: [],
stuColumn2: [],
stuColumn3: []
};
},
created() {
this.makeData(); // 頁面加載時(shí)給選擇框賦初始值
},
methods: {
makeData() { // 模擬數(shù)據(jù),生產(chǎn)環(huán)境用axios獲取數(shù)據(jù)
let column1 = [{
'kid': 0,
'text': '請(qǐng)選擇'
}, {
'kid': 1,
'text': '一年級(jí)'
}, {
'kid': 2,
'text': '二年級(jí)'
}];
let column2 = {
'1': [{
'kid': 1,
'text': '一組'
}, {
'kid': 2,
'text': '二組'
}, {
'kid': 3,
'text': '三組'
}],
'2': [{
'kid': 4,
'text': '四組'
}, {
'kid': 5,
'text': '五組'
}]
}
let column3 = {
'1': [{
'kid': 1,
'text': '小明'
}, {
'kid': 2,
'text': '小紅'
}, {
'kid': 3,
'text': '小剛'
}],
'2': [{
'kid': 4,
'text': 'Amy'
}, {
'kid': 5,
'text': 'Sam'
}],
'3': [{
'kid': 4,
'text': 'Sion'
}, {
'kid': 5,
'text': 'Juno'
}],
'4': [{
'kid': 6,
'text': 'Lucy'
}, {
'kid': 7,
'text': 'Tom'
}],
'5': [{
'kid': 6,
'text': 'Iwan'
}]
}
let columns = [];
columns = [{
values: column1,
defaultIndex: 0 //默認(rèn)選中項(xiàng)索引
},
{
values: [],
defaultIndex: 0
},
{
values: [],
defaultIndex: 0
}
];
this.stuColumn2 = column2;
this.stuColumn3 = column3;
this.stuLoad = columns;
},
stuConfirm(value, index) { // 下方彈出層點(diǎn)擊確認(rèn)時(shí)觸發(fā)
// value為各列選中值
// index為各列選中的索引
if (index.indexOf(0) > -1) {
alert('請(qǐng)選擇');
} else {
let content = value[0]['text'] + ' / ' + value[1]['text'] + ' / ' + value[2]['text'];
this.student = content;
this.stuShow = false;
}
},
stuChange(picker, value, index) { // 選擇器改變時(shí)觸發(fā)
// Picker 實(shí)例
// value為當(dāng)前選中值
// index為當(dāng)前列對(duì)應(yīng)的索引,第一列index為0,第二列index為1,依次列推
if (index == 0) { // 改變第一列的值
let i = value[0]['kid'];
let item = this.stuColumn2[i] ? this.stuColumn2[i] : [];
if (item && item[0]['text'] != '請(qǐng)選擇') {
item.unshift({
'kid': 0,
'text': '請(qǐng)選擇'
})
}
picker.setColumnValues(1, item); // 給對(duì)應(yīng)的列賦值,第一個(gè)參數(shù)為列的index值,第二個(gè)參數(shù)為列的values
} else if (index == 1) {
let i = value[1]['kid'];
let item = this.stuColumn3[i] ? this.stuColumn3[i] : [];
if (item.length != 0 && item[0]['text'] != '請(qǐng)選擇') {
item.unshift({
'kid': 0,
'text': '請(qǐng)選擇'
})
}
picker.setColumnValues(2, item);
}
}
}
};
</script>
<style scoped>
.text {
text-align: right;
}
</style>
補(bǔ)充知識(shí):vue vant-picker選擇器的使用,及數(shù)據(jù)結(jié)構(gòu)的寫法
vant-picker組件columns屬性接收的是一個(gè)數(shù)組,如官方例子中:

它的數(shù)組是子項(xiàng)是一個(gè)簡(jiǎn)單是字符,但通常我們真實(shí)的數(shù)據(jù)子項(xiàng)都是對(duì)象,如:
colums:[ {name:'張三',age:18},{name:'李四',age:28}]
那么像這樣的數(shù)組該怎么顯示呢, vant-picker的value-key屬性就是解決這個(gè)問題的,如我要使用上面的數(shù)組,那么vant-picker
就是這樣

另外,如果數(shù)組中的子項(xiàng)含有鍵名為'text',那么value-key也可以不用設(shè)置,組件會(huì)默認(rèn)取這個(gè)鍵名,如colums:[ {text:'張三',age:18},{text:'李四',age:28}]
以上這篇vant picker+popup 自定義三級(jí)聯(lián)動(dòng)案例就是小編分享給大家的全部?jī)?nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
vue - props 聲明數(shù)組和對(duì)象操作
這篇文章主要介紹了vue - props 聲明數(shù)組和對(duì)象操作,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2020-07-07
詳解 vue better-scroll滾動(dòng)插件排坑
本篇文章主要介紹了詳解 vue better-scroll滾動(dòng)插件排坑,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2018-02-02
解決vue?eslint開發(fā)嚴(yán)格模式警告錯(cuò)誤的問題
這篇文章主要介紹了解決vue?eslint開發(fā)嚴(yán)格模式警告錯(cuò)誤的問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-04-04
vue如何動(dòng)態(tài)修改$router參數(shù)
這篇文章主要介紹了vue如何動(dòng)態(tài)修改$router參數(shù),具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-09-09
Vue.js實(shí)現(xiàn)網(wǎng)格列表布局轉(zhuǎn)換方法
下面小編就為大家?guī)硪黄猇ue.js實(shí)現(xiàn)網(wǎng)格列表布局轉(zhuǎn)換方法。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2017-08-08
vue3+ts+vant移動(dòng)端H5項(xiàng)目搭建的實(shí)現(xiàn)步驟

