选择器 | Picker

Picker

选择器,支持多 slot 联动。

引入

import { Picker } from 'mint-ui'; Vue.component(Picker.name, Picker

例子

传入 slots,当被选中的值发生变化时触发 change 事件。change 事件有两个参数,分别为当前 picker 的 vue 实例和各 slot 被选中的值组成的数组

<mt-picker :slots="slots" @change="onValuesChange"></mt-picker>

export default { methods: { onValuesChange(picker, values) { if (values[0] > values[1]) { picker.setSlotValue(1, values[0] } } }, data() { return { slots: [ { flex: 1, values: ['2015-01', '2015-02', '2015-03', '2015-04', '2015-05', '2015-06'], className: 'slot1', textAlign: 'right' }, { divider: true, content: '-', className: 'slot2' }, { flex: 1, values: ['2015-01', '2015-02', '2015-03', '2015-04', '2015-05', '2015-06'], className: 'slot3', textAlign: 'left' } ] }; } };

change 事件

change 事件中,可以使用注册到 picker 实例上的一些方法:

  • getSlotValue(index):获取给定 slot 目前被选中的值

slots

绑定到 slots 属性的数组由对象组成,每个对象都对应一个 slot,它们有如下键名

key描述
divider对应 slot 是否为分隔符
content分隔符 slot 的显示文本
values对应 slot 的备选值数组。若为对象数组,则需在 mt-picker 标签上设置 value-key 属性来指定显示的字段名
defaultIndex对应 slot 初始选中值,需传入其在 values 数组中的序号,默认为 0
textAlign对应 slot 的对齐方式
flex对应 slot CSS 的 flex 值
className对应 slot 的类名

API

参数说明类型可选值默认值
slotsslot 对象数组Array[]
valueKey当 values 为对象数组时,作为文本显示在 Picker 中的对应字段的字段名String''
showToolbar是否在组件顶部显示一个 toolbar,内容自定义Booleanfalse
visibleItemCountslot 中可见备选值的个数Number5
itemHeight每个 slot 的高度Number36

Slot

name描述
-当 showToolbar 为 true 时,toolbar 中的内容