使用vant-picker实现自定义内容,根据内容添加图标

 更新时间:2022年12月06日 09:48:12   作者:妍崽崽@  
这篇文章主要介绍了使用vant-picker实现自定义内容,根据内容添加图标,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教

前言

在使用vant的框架的时候发现一件事,他的下拉内容只能输入文字,不可以是自定义,比如加图标,所以使用它的class名,然后仿照他的功能给完善了下,可以实现了自定义添加内容

实现效果

vant原来框架的内容:

我经过处理以后的效果图

这里的图片地址没有,如果满足条件,前面就有图片

实现步骤 

1、template部分

我这上面是vant的picker,可以打开看看之前的效果,这里是仿照他的效果实现的功能

 <van-popup v-model="showPicker" position="bottom">
<!--        <van-picker-->
<!--          show-toolbar-->
<!--          :columns="enterpriseList"-->
<!--          @cancel="showPicker = false"-->
<!--          @confirm="onConfirm"-->
<!--        >-->
<!--        <an-picker>-->
 
               <compicker-->
                      :enterpriseList="enterpriseList"
                       @cancel="showPicker = false"
                      @onConfirm="onConfirm">
                </compicker>
 
        <div class="van-picker">
          <div class="van-hairline--top-bottom van-picker__toolbar">
            <div class="van-picker__cancel" @click="showPicker = false">取消</div>
            <div class="van-picker__confirm" @click="onConfirm(enterpriseList[picker_active])">确认</div>
          </div>
          <div class="van-picker__columns" style="height: 220px">
            <div class="van-picker-column"
                 @scroll="change_picker_scroll"
                 style="height: 220px;overflow-y: auto;">
              <ul class="transition: all 0ms ease 0s; transform: translate3d(0px, 88px, 0px)"style="line-height: 44px">
                <li :class='{"van-picker-column__item--selected":picker_active==index}'
                    class="van-ellipsis van-picker-column__item"
                    style="height: 44px"
                    @click="change_picker(item,index)"
                    v-for="(item,index) in enterpriseList" :key="index">
<!--                  <img v-if="item.jfzt=='1'" src=""/>-->
                  <span v-if="item.jfzt=='1'"><img src="src"></span>
                  {{item.text}}<>
              </ul>
 
            </div>
          </div>
        </div>
 
 
 
 
      <an-popup>

2、data部分

picker_active:1,//因为要弄一个上面有空格的效果,所以初始化从第二个开始

3、methods部分

//点击确定事件
onConfirm(value) {
      this.enterprise = value;
      this.showPicker = false;
    },
    /**
     * 自定义picker得点击事件
     * */
    change_picker(item,index) {
      this.picker_active=index;
    } ,
//滚动条滚动事件
 change_picker_scroll(v){
      let scrollTop = v.srcElement.scrollTop;
      this.picker_active = Math.ceil(scrollTop/44)+1;//向上取整,并加上第一个空格
    },

获取数据那里的方法:

 this.enterpriseList = this.enterpriseList.map((item) => {
              return {
                keyId: item.id,
                nsrsbh: item.nsrsbh,
                text: item.nsrmc,
                jfzt:item.jfzt  //是否付费
 
              };
            });
            //上面加1行空格
            this.enterpriseList.unshift({});

到此结束~

总结

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

相关文章

  • 解决vuecli3中img src 的引入问题

    解决vuecli3中img src 的引入问题

    这篇文章主要介绍了解决vuecli3中img src 的引入问题,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2020-08-08
  • vue对象添加属性(key:value)、显示和删除属性方式

    vue对象添加属性(key:value)、显示和删除属性方式

    这篇文章主要介绍了vue对象添加属性(key:value)、显示和删除属性方式,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-07-07
  • 详解Vue项目中实现锚点定位

    详解Vue项目中实现锚点定位

    这篇文章主要介绍了Vue项目中实现锚点定位,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2019-04-04
  • vue配置请求本地json数据的方法

    vue配置请求本地json数据的方法

    这篇文章主要介绍了vue配置请求本地json数据的方法,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2018-04-04
  • vue实现多个el-form表单提交统一校验的2个方法

    vue实现多个el-form表单提交统一校验的2个方法

    这篇文章主要给大家介绍了关于vue实现多个el-form表单提交统一校验的2个方法,文中通过代码示例介绍的非常详细,对大家学习或使用vue具有一定的参考借鉴价值,需要的朋友可以参考下
    2023-07-07
  • vue的table表格组件的封装方式

    vue的table表格组件的封装方式

    这篇文章主要介绍了vue的table表格组件的封装方式,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2023-06-06
  • Vue动态获取width的方法

    Vue动态获取width的方法

    今天小编就为大家分享一篇Vue动态获取width的方法,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2018-08-08
  • 解决vuejs项目里css引用背景图片不能显示的问题

    解决vuejs项目里css引用背景图片不能显示的问题

    今天小编就为大家分享一篇解决vuejs项目里css引用背景图片不能显示的问题,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2018-09-09
  • 如何用vue2+element-ui实现多行行内表格编辑

    如何用vue2+element-ui实现多行行内表格编辑

    最近开发项目,关于表格的数据操作比较多,这个地方个人觉得比较难搞,特此记录一下,这篇文章主要给大家介绍了关于如何用vue2+element-ui实现多行行内表格编辑的相关资料,需要的朋友可以参考下
    2024-08-08
  • vue项目中axios如何捕捉http状态码为401错误问题

    vue项目中axios如何捕捉http状态码为401错误问题

    这篇文章主要介绍了vue项目中axios如何捕捉http状态码为401错误问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2024-03-03

最新评论