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

 更新时间:2023年01月17日 16:44:00   作者:weixin_45121510  
这篇文章主要介绍了van-picker组件default-index属性设置不生效踩坑及解决方案,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教

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

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

总结

以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。

相关文章

  • Vue 过滤器filters及基本用法

    Vue 过滤器filters及基本用法

    这篇文章主要介绍了Vue 过滤器filters的实例代码以及vue过滤器的基本用法,需要的朋友可以参考下
    2017-12-12
  • Vue父组件调用子组件事件方法

    Vue父组件调用子组件事件方法

    下面小编就为大家分享一篇Vue父组件调用子组件事件方法,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2018-02-02
  • vue的.vue文件是怎么run起来的(vue-loader)

    vue的.vue文件是怎么run起来的(vue-loader)

    通过vue-loader,解析.vue文件,在webpack解析,拆解vue组件 ,本文通过实例代码给大家介绍的非常详细,具有一定的参考借鉴价值,需要的朋友参考下
    2018-12-12
  • vue 全选与反选的实现方法(无Bug 新手看过来)

    vue 全选与反选的实现方法(无Bug 新手看过来)

    下面小编就为大家分享一篇vue 全选与反选的实现方法(无Bug 新手看过来),具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2018-02-02
  • VueUse功能精简你的dependencies

    VueUse功能精简你的dependencies

    这篇文章主要为大家介绍了VueUse功能精简你的dependencies实现示例,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2022-07-07
  • 关于element-ui中@selection-change执行两次的问题

    关于element-ui中@selection-change执行两次的问题

    这篇文章主要介绍了关于element-ui中@selection-change执行两次的问题,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-08-08
  • 解决nuxt 自定义全局方法,全局属性,全局变量的问题

    解决nuxt 自定义全局方法,全局属性,全局变量的问题

    这篇文章主要介绍了解决nuxt 自定义全局方法,全局属性,全局变量的问题,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2020-11-11
  • vue实现一拉到底的滑动验证

    vue实现一拉到底的滑动验证

    这篇文章主要为大家详细介绍了vue简单的一拉到底的滑动验证,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2019-07-07
  • 关于vue3 vuex4 store的响应式取值问题解决

    关于vue3 vuex4 store的响应式取值问题解决

    这篇文章主要介绍了vue3 vuex4 store的响应式取值问题,在实际生活中遇到这样一个问题:在页面中点击按钮,数量增加,值是存在store中的,点击事件值没变,如何解决这个问题,本文给大家分享解决方法,需要的朋友可以参考下
    2022-08-08
  • 浅析vue插槽和作用域插槽的理解

    浅析vue插槽和作用域插槽的理解

    插槽,也就是slot,是组件的一块HTML模板,这块模板显示不现实、以及怎样显示由父组件来决定。这篇文章主要介绍了浅析vue插槽和作用域插槽的理解,需要的朋友可以参考下
    2019-04-04

最新评论