首页前端开发VUEvan-picker组件default-index属性设置不生效踩坑及解决

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

时间2024-02-11 04:25:03发布访客分类VUE浏览1061
导读:收集整理的这篇文章主要介绍了van-picker组件default-index属性设置不生效踩坑及解决,觉得挺不错的,现在分享给大家,也给大家做个参考。 目录van-picker组件de...
收集整理的这篇文章主要介绍了van-picker组件default-index属性设置不生效踩坑及解决,觉得挺不错的,现在分享给大家,也给大家做个参考。
目录
  • van-picker组件default-index属性设置不生效
  • vant picker组件踩坑
    • 方法一
    • 方法二
    • 方法三
  • 总结

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

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

    总结

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

    您可能感兴趣的文章:
    • Vant Weapp组件踩坑:picker的初始赋值解决
    • vant的picker的坑及解决
    • 解决vue prop传值default属性如何使用,为何不生效的问题

    声明:本文内容由网友自发贡献,本站不承担相应法律责任。对本内容有异议或投诉,请联系2913721942#qq.com核实处理,我们将尽快回复您,谢谢合作!


    若转载请注明出处: van-picker组件default-index属性设置不生效踩坑及解决
    本文地址: https://pptw.com/jishu/609316.html
    Vue slot插槽作用与原理深入讲解 el-input无法输入的问题和表单验证失败问题解决

    游客 回复需填写必要信息