基于 mpvue 框架的小程序选择组件,支持单列,多列,级联

mpvue-picker

前言

mpvue开源之初写了 用 vue 写小程序,基于 mpvue 框架重写 weui。当时用的是小程序的原生组件,没有对其进行封装和组件化。而对于现在的前端开发环境,组件化模块化工程化以及自动化已经是一种标配。而mpvue框架又提供了一个很好的组件化开发平台,因此就对小程序中的 picker 组件进行封装,使其在用mpvue开发的时候能够用快速的实现 picker的功能。

为什么封装 picker 组件

  • 其实小程序提供了原生的 picker 组件,但是在开发的时候会发现在 android 手机上看到的 picker效果与微信开发者工具预览的效果不一样,其实就是丑了一点点...
  • 在小程序中使用 picker 的地方很多,很常见。

使用

  • 安装
npm install mpvue-picker --save 或者 cnpm install mpvue-picker --save
复制代码
  • 在页面中使用
<template>
  <div class="mpvue-picer">
    <button @click="showPicker">test for mpvuePicker</button>
    <mpvue-picker ref="mpvuePicker" :pickerValueArray="pickerValueArray" :pickerValueDefault='pickerValueDefault' @pickerConfirm="pickerConfirm"></mpvue-picker>
  </div>
</template>

<script>
import mpvuePicker from 'mpvue-picker';
export default {
  components: {
    mpvuePicker
  },
  data() {
    return {
      pickerValueArray: ['住宿费', '礼品费', '活动费', '通讯费', '补助'],
      pickerValueDefault: [1]
    };
  },
  methods: {
    showPicker() {
      this.$refs.mpvuePicker.show();
    },
    pickerConfirm(e) {
      console.log(e);
    }
  }
};
</script>

<style>
</style>

复制代码
  • 初始化

在父组件中调用 mpvuePicker 实例中的 show 方法即可。

参数说明

mode

  • 说明:picker 组件类型
  • 类型:String
  • 可选值:
    • selector(单列)
    • multiSelector(多列)
    • multiLinkageSelector(级联)
  • 是否必填: 否
  • 默认值:selector

pickerValueArray

  • 说明:picker 渲染数据
  • 类型:Array
  • 可选值:-
  • 是否必填: 是
  • 默认值:-

pickerValueDefault

  • 说明:picker 默认选中值
  • 类型:Array
  • 可选值:-
  • 是否必填: 否
  • 默认值:[]

deepLength

  • 说明:几级联动
  • 类型:Number
  • 可选值:
    • 2
    • 3
  • 是否必填: 否
  • 默认值:2

onChange

  • 说明:picer 组件滚动时回调,返回选中的数组索引
  • 类型:EventHandle
  • 可选值:-
  • 是否必填: 否
  • 默认值:-

onConfirm

  • 说明:picer 组件点击确定时回调,返回选中的数组索引
  • 类型:EventHandle
  • 可选值:-
  • 是否必填: 否
  • 默认值:-

效果

相关数据结构说明

单列
pickerValueArray: ['住宿费', '礼品费', '活动费', '通讯费', '补助']
复制代码
多列
pickerValueArray: [
  ['中国', '美国', '日本', '俄罗斯'],
  ['茶', '咖啡', '寿司', '奶酪'],
  ['歼20', 'F22', '秋月级', 'T50']
]
复制代码
点击展开二级联动数据结构
pickerValueArray:
[
  {
    label: '飞机票',
    value: 0,
    children: [{
      label: '经济舱',
      value: 1
    },
    {
      label: '商务舱',
      value: 2
    }
    ]
  },
  {
    label: '火车票',
    value: 1,
    children: [{
      label: '卧铺',
      value: 1
    },
    {
      label: '坐票',
      value: 2
    },
    {
      label: '站票',
      value: 3
    }
    ]
  },
  {
    label: '汽车票',
    value: 3,
    children: [{
      label: '快班',
      value: 1
    },
    {
      label: '普通',
      value: 2
    }
    ]
  }
]
复制代码
点击展开三级联动数据结构
pickerValueArray:
[
  {
    label: 'phone',
    value: 0,
    children: [
      {
        label: 'iphone',
        value: 1,
        children: [{
          label: 'iphoneX',
          value: 1
        },
        {
          label: 'iphone8',
          value: 2
        }, {
          label: 'iphone8 Plus',
          value: 3
        }]
      },
      {
        label: 'android',
        value: 1,
        children: [
          {
            label: 'vivo',
            value: 1
          },
          {
            label: '魅族',
            value: 2
          }, {
            label: '小米',
            value: 3
          }
        ]
      }
    ]
  },
  {
    label: 'PC',
    value: 0,
    children: [
      {
        label: 'mac',
        value: 1,
        children: [
          {
            label: 'macbook Pro',
            value: 1
          },
          {
            label: 'iMac',
            value: 2
          }, {
            label: 'mackbook',
            value: 3
          }, {
            label: 'mackbook air',
            value: 3
          }
        ]
      },
      {
        label: 'windows',
        value: 1,
        children: [
          {
            label: 'dell',
            value: 1
          },
          {
            label: 'surface',
            value: 2
          }, {
            label: 'thinkpad',
            value: 3
          }
        ]
      }
    ]
  }
]
复制代码

相关说明

对于多级联动,由于没有动态添加 picker 列数以及动态渲染其值,因此目前只支持 二级联动和三级联动。

TODO

  • 增加时间选择 mode
  • 增加日期选择 mode
  • 增加城市选择 mode

结束语

mpvue-picker 地址

万水千山总是情,给个 star 行不行~

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
好的,我可以为您提供一些思路和方案。 首先,自定义字段名的级联选择一般可以通过两种方式实现: 1. 使用Picker组件实现级联选择; 2. 使用自定义组件实现级联选择。 下面我分别为您介绍这两种实现方式的具体步骤和注意事项。 1. 使用Picker组件实现级联选择 步骤: 1)在wxml文件中定义三个Picker组件,分别用于选择一级、二级和三级字段名。例如: ``` <view class="picker-box"> <view class="picker-item"> <picker mode="selector" range="{{level1}}" bindchange="pickerChange1"> <view class="picker-value">{{value1}}</view> </picker> </view> <view class="picker-item"> <picker mode="selector" range="{{level2}}" bindchange="pickerChange2"> <view class="picker-value">{{value2}}</view> </picker> </view> <view class="picker-item"> <picker mode="selector" range="{{level3}}" bindchange="pickerChange3"> <view class="picker-value">{{value3}}</view> </picker> </view> </view> ``` 2)在js文件中定义三个数组,分别用于存储一级、二级和三级字段名。例如: ``` Page({ data: { level1: ['字段名1', '字段名2', '字段名3'], level2: [], level3: [], value1: 0, value2: 0, value3: 0, }, pickerChange1: function (e) { // 级联选择,更新二级字段名 let level2 = []; let value1 = e.detail.value; switch (value1) { case 0: level2 = ['字段名1-1', '字段名1-2']; break; case 1: level2 = ['字段名2-1', '字段名2-2']; break; case 2: level2 = ['字段名3-1', '字段名3-2']; break; } this.setData({ level2: level2, value1: value1, value2: 0, value3: 0, }); }, pickerChange2: function (e) { // 级联选择,更新三级字段名 let level3 = []; let value2 = e.detail.value; switch (value2) { case 0: level3 = ['字段名1-1-1', '字段名1-1-2']; break; case 1: level3 = ['字段名1-2-1', '字段名1-2-2']; break; case 2: level3 = ['字段名2-1-1', '字段名2-1-2']; break; case 3: level3 = ['字段名2-2-1', '字段名2-2-2']; break; case 4: level3 = ['字段名3-1-1', '字段名3-1-2']; break; case 5: level3 = ['字段名3-2-1', '字段名3-2-2']; break; } this.setData({ level3: level3, value2: value2, value3: 0, }); }, pickerChange3: function (e) { // 更新三级字段名 let value3 = e.detail.value; this.setData({ value3: value3, }); }, }) ``` 注意事项: 1)在Picker组件中,mode属性必须设置为selector; 2)在js文件中,必须定义三个数组分别用于存储一级、二级和三级字段名; 3)在pickerChange1和pickerChange2函数中,必须根据一级和二级字段名的选择更新二级和三级字段名的数组; 4)在pickerChange3函数中,只需要更新三级字段名即可。 2. 使用自定义组件实现级联选择 步骤: 1)在wxml文件中定义一个自定义组件,例如: ``` <view class="picker-box"> <custom-picker level="{{level1}}" bindchange="pickerChange"></custom-picker> <custom-picker level="{{level2}}" bindchange="pickerChange"></custom-picker> <custom-picker level="{{level3}}" bindchange="pickerChange"></custom-picker> </view> ``` 2)在js文件中定义一个数组,用于存储所有的字段名。例如: ``` Page({ data: { fields: [ ['字段名1', '字段名2', '字段名3'], ['字段名1-1', '字段名1-2', '字段名2-1', '字段名2-2', '字段名3-1', '字段名3-2'], ['字段名1-1-1', '字段名1-1-2', '字段名1-2-1', '字段名1-2-2', '字段名2-1-1', '字段名2-1-2', '字段名2-2-1', '字段名2-2-2', '字段名3-1-1', '字段名3-1-2', '字段名3-2-1', '字段名3-2-2'], // 更多级别的字段名可以继续添加 ], value: [0, 0, 0], }, pickerChange: function (e) { let value = e.detail.value; this.setData({ value: value, }); }, }) ``` 3)在自定义组件中,使用Picker组件实现级联选择。例如: ``` Component({ properties: { level: { type: Array, value: [], }, }, data: { value: 0, }, methods: { pickerChange: function (e) { let value = e.detail.value; this.setData({ value: value, }); this.triggerEvent('change', {value: value}); }, }, }) ``` 注意事项: 1)自定义组件中,必须使用Picker组件实现级联选择,并且在自定义组件的properties中定义level属性,用于接收父组件传递的数组; 2)在js文件中,必须定义一个数组用于存储所有的字段名,并在pickerChange函数中根据选择的值更新value数组; 3)在自定义组件中,必须定义一个change事件,并在pickerChange函数中触发该事件,将value的值传递给父组件。 以上是两种实现级联选择的方式,您可以根据自己的需要选取适合的方法。希望能够帮助到您。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值