【微信小程序遇到的坑】使用picker组件

普通picker组件写法

js

Page({
  data: {
    jobTypeArray: ['请选择职称', '医师', '护士'],//科室类型
    jobIndex: 0,//科室类型类型id
  },
  jobPickerChange(e) {
    this.setData({
      jobIndex: e.detail.value
    })
  }
})

键值对picker组件写法

js

Page({
  data: {
     jobTypeArray: [{
      id: 0,
      name: "请选择科室"
    }, {
      id: 1,
      name: "不孕不育"
    }, {
      id: 2,
      name: "孕了也不是你的"
    }],
    jobIndex: 0,
  },
  jobPickerChange(e) {
    this.setData({
      jobIndex: e.detail.value
    })
  }
})

重点在于对wxml的写法,循环键值对数据,需要使用 range-key="{{'name'}}"

这里的参数name一定要带个引号

<picker bindchange="jobPickerChange" value="{{jobIndex}}" range="{{jobTypeArray}}" range-key="{{'name'}}">
     <view class="picker">
        {{jobTypeArray[jobIndex].name}}
     </view>
</picker>

实现效果如下


注:传参的时候,form默认提交的是选择第几个位置信息,那么想要得到对应的id信息,

需要 使用 that.data.array[that.data.arrayIndex].id 根据位置获取数据id的方式


  • 2
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值