效果
实现过程
1 2 3 4 5 6 7 8 9 10 11 12
| <view class="section"> <view class="section__title">{{title}}</view> <picker bindchange="bindPickerChange" value="{{multiIndex}}" range="{{multiArray}}" mode="multiSelector" bindcolumnchange="columnchange"> <view class="picker"> <view class='words'> {{multiArray[0][multiIndex[0]]}},{{multiArray[1][multiIndex[1]]}},{{multiArray[2][multiIndex[2]]}} </view> <image src='/image/right.png'></image> </view> </picker> </view>
|
在小程序已有的picker组件中设置mode="multiSelector"
,使之成为多列选择器。
在多列选择器中有两个重要的参数:
1 2 3 4
| properties: { multiArray: Array, multiIndex: Array }
|
multiArray是一个二维数组,存放选择器每一列上的选项列表。multiIndex是一个一维数组,存放每一列被选中的值,例:[0,0,0]
表示第一列选中了第0个选项,第二列也选中了第0个选项,以此类推。这两个参数都由用到三列选择器的页面传入。
在小程序已有的picker组件中绑定bindPickerChange事件和columnchange事件,当用户确定选择器的选项值或改变某列选项值时会分别触发这两个事件:
1 2 3 4 5 6 7 8 9
| methods: { bindPickerChange: function (e) { this.triggerEvent("multiSelectorValue", e.detail) }, columnchange: function (e) { this.triggerEvent("multiSelectorColumn", e.detail) } }
|
设置multiSelectorValue事件和multiSelectorColumn事件,来让用到三列选择器的页面捕捉到选择器选项值的改变。
在要用到三列选择器的页面里引入三列选择器组件,比如叫v-picker-multiSelector:
1
| <v-picker-multiSelector multiArray="{{multiArray}}" multiIndex="{{multiIndex}}" bind:multiSelectorValue="receiveMultiSelectorValue" bind:multiSelectorColumn="receiveMultiSelectorColumn"></v-picker-multiSelector>
|
通过设置receiveMultiSelectorValue函数和receiveMultiSelectorColumn函数来接收选项值的变化:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37
| receiveMultiSelectorColumn: function (e) { const column = e.detail.column const columnValue = e.detail.value switch (column) { case 0: this.data.multiIndex[0] = columnValue
this.data.multiArray[1] = this.testGetCity(this.data.provinceList[columnValue]) this.data.cityList = this.data.multiArray[1] this.data.multiIndex[1] = 0
this.data.multiArray[2] = this.testGetPlantingArea(this.data.cityList[0]) this.data.plantingAreaList = this.data.multiArray[2] this.data.multiIndex[2] = 0
this.setData({ multiArray: this.data.multiArray, multiIndex: this.data.multiIndex }) break
case 1: this.data.multiIndex[1] = columnValue
this.data.multiArray[2] = this.testGetPlantingArea(this.data.cityList[columnValue]) this.data.plantingAreaList = this.data.multiArray[2] this.data.multiIndex[2] = 0
this.setData({ multiArray: this.data.multiArray, multiIndex: this.data.multiIndex }) break } }
|
当三列选择器的某列值改变时,页面从组件里接收到改变的列数(column)和该列被选择的值(columnValue)。对column进行判断,如果column=0,那么根据columnValue的值向后端请求回该省的市列表,并根据市列表的的第一位向后端请求回该市的区列表。如果column=1,那么那么根据columnValue的值向后端请求回该市的区列表。
1 2 3 4 5 6 7 8 9 10 11 12
| receiveMultiSelectorValue: function (e) { this.setData({ multiIndex: e.detail.value }) this.data.region[0] = this.data.multiArray[0][this.data.multiIndex[0]] this.data.region[1] = this.data.multiArray[1][this.data.multiIndex[1]] this.data.region[2] = this.data.multiArray[2][this.data.multiIndex[2]] this.setData({ region: this.data.region }) }
|
当用户确定三列选择器的选项时,页面从组件中接收到multiIndex的值,并对选项值进行更新。