博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
微信小程序_(组件)picker
阅读量:5224 次
发布时间:2019-06-14

本文共 9335 字,大约阅读时间需要 31 分钟。

 

 

 

picker组件效果  官方文档:

 

Page({  data: {    array: ['美国', '中国', '巴西', '日本'],    objectArray: [      {        id: 0,        name: '美国'      },      {        id: 1,        name: '中国'      },      {        id: 2,        name: '巴西'      },      {        id: 3,        name: '日本'      }    ],    index: 0,    multiArray: [['无脊柱动物', '脊柱动物'], ['扁性动物', '线形动物', '环节动物', '软体动物', '节肢动物'], ['猪肉绦虫', '吸血虫']],    objectMultiArray: [      [        {          id: 0,          name: '无脊柱动物'        },        {          id: 1,          name: '脊柱动物'        }      ], [        {          id: 0,          name: '扁性动物'        },        {          id: 1,          name: '线形动物'        },        {          id: 2,          name: '环节动物'        },        {          id: 3,          name: '软体动物'        },        {          id: 3,          name: '节肢动物'        }      ], [        {          id: 0,          name: '猪肉绦虫'        },        {          id: 1,          name: '吸血虫'        }      ]    ],    multiIndex: [0, 0, 0],    date: '2016-09-01',    time: '12:01',    region: ['广东省', '广州市', '海珠区'],    customItem: '全部'  },  bindPickerChange: function (e) {    console.log('picker发送选择改变,携带值为', e.detail.value)    this.setData({      index: e.detail.value    })  },  bindMultiPickerChange: function (e) {    console.log('picker发送选择改变,携带值为', e.detail.value)    this.setData({      multiIndex: e.detail.value    })  },  bindMultiPickerColumnChange: function (e) {    console.log('修改的列为', e.detail.column, ',值为', e.detail.value);    var data = {      multiArray: this.data.multiArray,      multiIndex: this.data.multiIndex    };    data.multiIndex[e.detail.column] = e.detail.value;    switch (e.detail.column) {      case 0:        switch (data.multiIndex[0]) {          case 0:            data.multiArray[1] = ['扁性动物', '线形动物', '环节动物', '软体动物', '节肢动物'];            data.multiArray[2] = ['猪肉绦虫', '吸血虫'];            break;          case 1:            data.multiArray[1] = ['鱼', '两栖动物', '爬行动物'];            data.multiArray[2] = ['鲫鱼', '带鱼'];            break;        }        data.multiIndex[1] = 0;        data.multiIndex[2] = 0;        break;      case 1:        switch (data.multiIndex[0]) {          case 0:            switch (data.multiIndex[1]) {              case 0:                data.multiArray[2] = ['猪肉绦虫', '吸血虫'];                break;              case 1:                data.multiArray[2] = ['蛔虫'];                break;              case 2:                data.multiArray[2] = ['蚂蚁', '蚂蟥'];                break;              case 3:                data.multiArray[2] = ['河蚌', '蜗牛', '蛞蝓'];                break;              case 4:                data.multiArray[2] = ['昆虫', '甲壳动物', '蛛形动物', '多足动物'];                break;            }            break;          case 1:            switch (data.multiIndex[1]) {              case 0:                data.multiArray[2] = ['鲫鱼', '带鱼'];                break;              case 1:                data.multiArray[2] = ['青蛙', '娃娃鱼'];                break;              case 2:                data.multiArray[2] = ['蜥蜴', '龟', '壁虎'];                break;            }            break;        }        data.multiIndex[2] = 0;        console.log(data.multiIndex);        break;    }    this.setData(data);  },  bindDateChange: function (e) {    console.log('picker发送选择改变,携带值为', e.detail.value)    this.setData({      date: e.detail.value    })  },  bindTimeChange: function (e) {    console.log('picker发送选择改变,携带值为', e.detail.value)    this.setData({      time: e.detail.value    })  },  bindRegionChange: function (e) {    console.log('picker发送选择改变,携带值为', e.detail.value)    this.setData({      region: e.detail.value    })  }})
test.js

 

Gary 微信小程序
普通选择器
当前选择:{
{array[index]}}
多列选择器
当前选择:{
{multiArray[0][multiIndex[0]]}},{
{multiArray[1][multiIndex[1]]}},{
{multiArray[2][multiIndex[2]]}}
时间选择器
当前选择: {
{time}}
日期选择器
当前选择: {
{date}}
省市区选择器
当前选择:{
{region[0]}},{
{region[1]}},{
{region[2]}}
test.wxml

 

{  "pages":[    "pages/test/test",    "pages/index/index",    "pages/logs/logs"  ],  "window":{    "backgroundTextStyle":"light",    "navigationBarBackgroundColor": "#fff",    "navigationBarTitleText": "WeChat",    "navigationBarTextStyle":"black"  }}
app.json

 

  

  picker底部弹起的滚动选择器  支持五种选择器 :普通选择器,多列选择器,时间选择器,日期选择器,省市区选择器

 

实现过程

 

  普通选择器

普通选择器
当前选择:{
{array[index]}}

 

  绑定数值到选择器上,index初始化时下标为0

array: ['美国', '中国', '巴西', '日本'],    objectArray: [      {        id: 0,        name: '美国'      },      {        id: 1,        name: '中国'      },      {        id: 2,        name: '巴西'      },      {        id: 3,        name: '日本'      }    ],
    index: 0,
 

 

 
 多列选择器
多列选择器
当前选择:{
{multiArray[0][multiIndex[0]]}},{
{multiArray[1][multiIndex[1]]}},{
{multiArray[2][multiIndex[2]]}}

 

  绑定数值到选择器上,multiIndex: [0, 0, 0]初始化时指向第一个元素

multiArray: [['无脊柱动物', '脊柱动物'], ['扁性动物', '线形动物', '环节动物', '软体动物', '节肢动物'], ['猪肉绦虫', '吸血虫']],    objectMultiArray: [      [        {          id: 0,          name: '无脊柱动物'        },        {          id: 1,          name: '脊柱动物'        }      ], [        {          id: 0,          name: '扁性动物'        },        {          id: 1,          name: '线形动物'        },        {          id: 2,          name: '环节动物'        },        {          id: 3,          name: '软体动物'        },        {          id: 3,          name: '节肢动物'        }      ], [        {          id: 0,          name: '猪肉绦虫'        },        {          id: 1,          name: '吸血虫'        }      ]    ],    multiIndex: [0, 0, 0],

 

 
 时间选择器
时间选择器
当前选择: {
{time}}

 

  绑定数值到选择器上,初始化时时间为12:01

time: '12:01',

 

  日期选择器

日期选择器
当前选择: {
{date}}

 

  绑定数值到选择器上,初始化时日期为date: '2016-09-01',

date: '2016-09-01',

 

  省市区选择器
省市区选择器
当前选择:{
{region[0]}},{
{region[1]}},{
{region[2]}}

 

  绑定数值到选择器上,初始化时为 广东省-广州市-海珠区

region: ['广东省', '广州市', '海珠区'],

 

  

 添加函数绑定到选择器上滑动选择器可修改选择器上的数值

bindPickerChange: function (e) {    console.log('picker发送选择改变,携带值为', e.detail.value)    this.setData({      index: e.detail.value    })  },  bindMultiPickerChange: function (e) {    console.log('picker发送选择改变,携带值为', e.detail.value)    this.setData({      multiIndex: e.detail.value    })  },  bindMultiPickerColumnChange: function (e) {    console.log('修改的列为', e.detail.column, ',值为', e.detail.value);    var data = {      multiArray: this.data.multiArray,      multiIndex: this.data.multiIndex    };    data.multiIndex[e.detail.column] = e.detail.value;    switch (e.detail.column) {      case 0:        switch (data.multiIndex[0]) {          case 0:            data.multiArray[1] = ['扁性动物', '线形动物', '环节动物', '软体动物', '节肢动物'];            data.multiArray[2] = ['猪肉绦虫', '吸血虫'];            break;          case 1:            data.multiArray[1] = ['鱼', '两栖动物', '爬行动物'];            data.multiArray[2] = ['鲫鱼', '带鱼'];            break;        }        data.multiIndex[1] = 0;        data.multiIndex[2] = 0;        break;      case 1:        switch (data.multiIndex[0]) {          case 0:            switch (data.multiIndex[1]) {              case 0:                data.multiArray[2] = ['猪肉绦虫', '吸血虫'];                break;              case 1:                data.multiArray[2] = ['蛔虫'];                break;              case 2:                data.multiArray[2] = ['蚂蚁', '蚂蟥'];                break;              case 3:                data.multiArray[2] = ['河蚌', '蜗牛', '蛞蝓'];                break;              case 4:                data.multiArray[2] = ['昆虫', '甲壳动物', '蛛形动物', '多足动物'];                break;            }            break;          case 1:            switch (data.multiIndex[1]) {              case 0:                data.multiArray[2] = ['鲫鱼', '带鱼'];                break;              case 1:                data.multiArray[2] = ['青蛙', '娃娃鱼'];                break;              case 2:                data.multiArray[2] = ['蜥蜴', '龟', '壁虎'];                break;            }            break;        }        data.multiIndex[2] = 0;        console.log(data.multiIndex);        break;    }    this.setData(data);  },  bindDateChange: function (e) {    console.log('picker发送选择改变,携带值为', e.detail.value)    this.setData({      date: e.detail.value    })  },  bindTimeChange: function (e) {    console.log('picker发送选择改变,携带值为', e.detail.value)    this.setData({      time: e.detail.value    })  },  bindRegionChange: function (e) {    console.log('picker发送选择改变,携带值为', e.detail.value)    this.setData({      region: e.detail.value    })  }

 

转载于:https://www.cnblogs.com/1138720556Gary/p/9445528.html

你可能感兴趣的文章
从java字节码角度看线程安全性问题
查看>>
Java源码之 java.util.concurrent 学习笔记01
查看>>
洛谷P1175 表达式的转换
查看>>
Android实现类似换QQ头像功能(图片裁剪)
查看>>
PHP开发者应了解的24个库
查看>>
var、const、let 的区别
查看>>
改进的排序算法
查看>>
[转载]哈佛经典——《管理自己》
查看>>
虚拟内存安排
查看>>
进制转换
查看>>
datasg中的数据的存储结
查看>>
PTA題目的處理(一)
查看>>
db2 存储BLOB格式的大对象
查看>>
UVA 12902 Reverse Polish Notation
查看>>
应考计划 2010-09-04
查看>>
VS快捷键(转)
查看>>
牛人博客收集
查看>>
0529
查看>>
跟踪数据库中执行时间超过1.5秒的语句及SP,导入数据库
查看>>
[转]详解Oracle高级分组函数(ROLLUP, CUBE, GROUPING SETS)
查看>>