当前位置: 代码网 > it编程>前端脚本>Vue.js > van-picker组件default-index属性设置不生效踩坑及解决

van-picker组件default-index属性设置不生效踩坑及解决

2024年05月20日 Vue.js 我要评论
van-picker组件default-index属性设置不生效官方文档:default-index 单列选择时,默认选中项的索引 number | string 0defaultindex 这个属性

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(); //执行一下
 }

目前想到的解决办法只有这三种!

总结

以上为个人经验,希望能给大家一个参考,也希望大家多多支持代码网。

(0)

相关文章:

版权声明:本文内容由互联网用户贡献,该文观点仅代表作者本人。本站仅提供信息存储服务,不拥有所有权,不承担相关法律责任。 如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 2386932994@qq.com 举报,一经查实将立刻删除。

发表评论

验证码:
Copyright © 2017-2025  代码网 保留所有权利. 粤ICP备2024248653号
站长QQ:2386932994 | 联系邮箱:2386932994@qq.com