欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

vant picker+popup 自定義三級聯(lián)動案例

 更新時間:2020年11月04日 10:21:34   作者:瘋狂的韭菜  
這篇文章主要介紹了vant picker+popup 自定義三級聯(lián)動案例,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧

picker選擇器的數(shù)據(jù)由columns屬性控制,columns中有幾個元素就代表該選擇器有多少級,通過change方法來給對應列賦值。

columns = [{
    values: column1, // 對應列的值
    defaultIndex: 0, // 默認選中項索引
    className: 'class1' // 對應列的類名 
  },
  {
    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">自定義三級聯(lián)動</van-col>
    <van-col span="19">
      <van-field v-model="student" placeholder="請選擇" @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(); // 頁面加載時給選擇框賦初始值
  },
  methods: {
    makeData() { // 模擬數(shù)據(jù),生產(chǎn)環(huán)境用axios獲取數(shù)據(jù)
      let column1 = [{
        'kid': 0,
        'text': '請選擇'
      }, {
        'kid': 1,
        'text': '一年級'
      }, {
        'kid': 2,
        'text': '二年級'
      }];
      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 //默認選中項索引
        },
        {
          values: [],
          defaultIndex: 0
        },
        {
          values: [],
          defaultIndex: 0
        }
      ];
      this.stuColumn2 = column2;
      this.stuColumn3 = column3;
      this.stuLoad = columns;
    },
    stuConfirm(value, index) { // 下方彈出層點擊確認時觸發(fā)
      // value為各列選中值
      // index為各列選中的索引
      if (index.indexOf(0) > -1) {
        alert('請選擇');
      } else {
        let content = value[0]['text'] + ' / ' + value[1]['text'] + ' / ' + value[2]['text'];
        this.student = content;
        this.stuShow = false;
      }
    },
    stuChange(picker, value, index) { // 選擇器改變時觸發(fā)
      // Picker 實例
      // value為當前選中值
      // index為當前列對應的索引,第一列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'] != '請選擇') {
          item.unshift({
            'kid': 0,
            'text': '請選擇'
          })
        }
        picker.setColumnValues(1, item); // 給對應的列賦值,第一個參數(shù)為列的index值,第二個參數(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'] != '請選擇') {
          item.unshift({
            'kid': 0,
            'text': '請選擇'
          })
        }
        picker.setColumnValues(2, item);
      }
    }
  }
};
</script>

<style scoped>
.text {
  text-align: right;
}
</style>

補充知識:vue vant-picker選擇器的使用,及數(shù)據(jù)結構的寫法

vant-picker組件columns屬性接收的是一個數(shù)組,如官方例子中:

它的數(shù)組是子項是一個簡單是字符,但通常我們真實的數(shù)據(jù)子項都是對象,如:

colums:[ {name:'張三',age:18},{name:'李四',age:28}]

那么像這樣的數(shù)組該怎么顯示呢, vant-picker的value-key屬性就是解決這個問題的,如我要使用上面的數(shù)組,那么vant-picker

就是這樣

另外,如果數(shù)組中的子項含有鍵名為'text',那么value-key也可以不用設置,組件會默認取這個鍵名,如colums:[ {text:'張三',age:18},{text:'李四',age:28}]

以上這篇vant picker+popup 自定義三級聯(lián)動案例就是小編分享給大家的全部內(nèi)容了,希望能給大家一個參考,也希望大家多多支持腳本之家。

相關文章

  • vue - props 聲明數(shù)組和對象操作

    vue - props 聲明數(shù)組和對象操作

    這篇文章主要介紹了vue - props 聲明數(shù)組和對象操作,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2020-07-07
  • Vue按需加載的具體實現(xiàn)

    Vue按需加載的具體實現(xiàn)

    本篇文章主要介紹了Vue按需加載的具體實現(xiàn),小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-12-12
  • 詳解 vue better-scroll滾動插件排坑

    詳解 vue better-scroll滾動插件排坑

    本篇文章主要介紹了詳解 vue better-scroll滾動插件排坑,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-02-02
  • Vue之前端體系與前后端分離詳解

    Vue之前端體系與前后端分離詳解

    本篇文章主要介紹了Vue之前端體系與前后端分離,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2021-10-10
  • 解決vue?eslint開發(fā)嚴格模式警告錯誤的問題

    解決vue?eslint開發(fā)嚴格模式警告錯誤的問題

    這篇文章主要介紹了解決vue?eslint開發(fā)嚴格模式警告錯誤的問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-04-04
  • vue如何動態(tài)修改$router參數(shù)

    vue如何動態(tài)修改$router參數(shù)

    這篇文章主要介紹了vue如何動態(tài)修改$router參數(shù),具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-09-09
  • Vue.js實現(xiàn)網(wǎng)格列表布局轉換方法

    Vue.js實現(xiàn)網(wǎng)格列表布局轉換方法

    下面小編就為大家?guī)硪黄猇ue.js實現(xiàn)網(wǎng)格列表布局轉換方法。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-08-08
  • vue中ref實現(xiàn)子向父傳值的示例

    vue中ref實現(xiàn)子向父傳值的示例

    本文主要介紹了vue中ref實現(xiàn)子向父傳值的示例,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2023-01-01
  • vue element和nuxt的使用技巧分享

    vue element和nuxt的使用技巧分享

    這篇文章主要介紹了vue element和nuxt的使用技巧分享,幫助大家更好的理解和使用vue框架,感興趣的朋友可以了解下
    2021-01-01
  • vue3+ts+vant移動端H5項目搭建的實現(xiàn)步驟

    vue3+ts+vant移動端H5項目搭建的實現(xiàn)步驟

    本文主要介紹了vue3+ts+vant移動端H5項目搭建,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2022-06-06

最新評論