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-

本文介绍了在使用Vant Picker组件时遇到的问题,包括如何不显示顶部栏以及在change事件中遇到的1-2秒延迟问题。尝试了三种方法:绑定change事件、使用ref调用confirm方法和显示但隐藏顶部栏,最后提到尽管第三种方法可行,但仍寻求更优解。
最低0.47元/天 解锁文章
6174





