javascript - 小程序 picker 对于 objArray 怎么取值
问题描述
小程序 picker 组件,看 demo 里面是有 objArray 这个类型,但是又没有用到,我现在就是y有一组 objArray 需要用到,但是怎么都不能正常显示,麻烦大家帮忙看下:
小程序 demo 链接:picker
wxml:
<picker bindchange='bindPickerChange' value='{{index}}' range='{{objectArray}}'> <view class='picker'> 当前选择:{{objectArray[index]}} </view></picker>
js:
Page({ data: { objectArray: [ {id: 0,name: ’美国’ }, {id: 1,name: ’中国’ }, {id: 2,name: ’巴西’ }, {id: 3,name: ’日本’ } ] }, bindPickerChange: function(e) { console.log(’picker发送选择改变,携带值为’, e.detail.value) this.setData({ index: e.detail.value }) }})
这样的话,显示的下拉选项就是[object Object],选中之后在页面显示的也是这样,我现在是想下拉列表显示 name 里面的值,然后知道选中的 id,实在是不知道怎么实现了。。。
问题解答
回答1:使用这个属性应该是可以的,修改后的代码如下:
<picker bindchange='bindPickerChange' value='{{index}}' range-key='name' range='{{objectArray}}'> <view class='picker'> 当前选择:{{objectArray[index].name}} </view></picker>
Update1:
Page({ data: { objectArray: [ {id: 0,name: ’美国’ }, {id: 1,name: ’中国’ }, {id: 2,name: ’巴西’ }, {id: 3,name: ’日本’ } ] }, bindPickerChange: function(e) { console.log(’picker发送选择改变,携带值为’, e.detail.value) var index = e.detail.value; var currentId = this.data.objectArray[index].id; // 这个id就是选中项的id this.setData({ index: e.detail.value }) }})回答2:
添加 range-key=’obj.item’,例如
<picker bindchange='bindPickerChange' value='{{index}}' range-key='name' range='{{objectArray}}'> <view class='picker'> 当前选择:{{objectArray[index].name}} </view></picker
相关文章:
1. android - 百度地图加载大量marker点有没有比较好的解决方案2. html5 - 想要写一个H5页面,就微信打开来那种,然后几个输入框,把数据保存在我后台(java)的数据库里,实现思路是怎样的?3. 怎么在phpstudy中用phpexcel上传数据到MYSQL?4. vue.js - 为什么我的vue项目上传到github不能预览?5. java - springboot使用容器加载时,如何预先获取ClassLoader资源?6. boot2docker无法启动7. 请在微信客户端打开链接怎么在PC端打开8. java - AtomicInteger等原子类,是不是不用volatile修饰,自带volatile属性?9. css3 邊框漸層 及 ios背景模糊?10. android 百度地图设置个性化皮肤