van-picker组件default-index属性设置不生效踩坑及解决
短信预约 -IT技能 免费直播动态提醒
van-picker组件default-index属性设置不生效
官方文档:default-index 单列选择时,默认选中项的索引 number | string 0
defaultIndex 这个属性只是一个初始值,
如果需要动态改变 index索引:
建议使用 picker 实例的 setIndexes 方法
通过 ref 可以获取到 Picker 实例并调用实例方法,
setIndexes 设置所有列选中值对应的索引 indexes -
// 1.给van-picker设置ref,如ref="van_picker"
<van-popup v-model="showPicker" position="bottom">
<van-picker
show-toolbar value-key="label" ref="van_picker"
:columns="columns" :default-index="defaultBuIndex"
@confirm="onConfirm" @cancel="showPicker = false"
/>
</van-popup>
// 2. 在需要的方法中调用:
this.$nextTick(() =>{
this.$refs.van_picker.setIndexes([0]) // 注意这里是数组[索引值]
})
vant picker组件踩坑
vant Picker组件,不显示顶部栏,change事件拿到的值有1-2s延迟问题
ui设计如图
因需求要求,picker去掉顶部栏,点击下方确认按钮的时候获取选中的值
方法一
绑定change事件,选项改变时触发(但是有1s的延迟,操作太快了会取不到值,不可取)
<van-picker
:show-toolbar="true"
:columns="reason"
ref="picker"
@change="change"
/>
<div class="btn" @click="handlePopSubmit('reason')">确认</div>
change(value){
//单列:Picker 实例,选中值,选中值对应的索引
//多列:Picker 实例,所有列选中值,当前列对应的索引
}
方法二
通过使用ref,调用ref的confirm方法(和方法一是一样的,有1s的延迟,操作太快了会取不到值)
<van-picker
:show-toolbar="true"
:columns="reason"
ref="picker"
ref="pick"
/>
<div class="btn" @click="handlePopSubmit('reason')">确认</div>
handlePopSubmit(){
console.log('选中的值',this.$refs.picker.getValues)
}
方法三
有点笨拙,但是不会出问题
vant-picker的show-toolbar设置为true,但是在页面上对顶部的导航栏样式隐藏(例如:display:none)
<van-picker
:show-toolbar="true"
:columns="reason"
ref="picker"
@confirm="handleReasonChange"
/>
<div class="btn" @click="handlePopSubmit('reason')">确认</div>
handleReasonChange(value, index) {
//value :选中的值 取值即可
//index: 下标
}
handlePopSubmit(){
let pickReason = (this.$refs.picker as any).$el.children[0].children[1]; //拿到顶部栏的确认元素
pickReason.click(); //执行一下
}
目前想到的解决办法只有这三种!
总结
以上为个人经验,希望能给大家一个参考,也希望大家多多支持编程网。
免责声明:
① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。
② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341