vant的picker组件设置文字超长滚动方式

 更新时间:2022年12月06日 09:30:20   作者:_木兮_  
这篇文章主要介绍了vant的picker组件设置文字超长滚动方式,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教

picker组件设置文字超长滚动

我们的手机端使用vant来做前端UI框架。

今天在使用vant的picker组件时候,遇到了一个问题。当文字过长的时候,vant的处理方式是ellipsis,超长部分显示【…】

如果恰好省略号前边内容相同,用户就无法区分选项了。如图:

vant没有提供滚动的实现方式,所以我们自己兼容实现一下。

首先,打开开发者工具看下dom结构

我的思路是,如果在选中状态下,内层文字div长度大于外层的时候。给内层增加一个滚动动画效果。

实现如下:

  • 重写.van-ellipsis两个样式,去掉ellipsis效果和overflow:hidden
  • 监听picker的change事件
  • 在dom渲染结束之后,获取.van-picker-column__item–selected并判断它与内部文字的宽度
  • 如果内部组件宽度大于外部,在添加一个animation
<template>
  <div id="app">
    <van-picker show-toolbar title="标题" :columns="columns" @change="checkScroll" />
  </div>
</template>
<script>
export default {
  name: 'App',
  data () {
    return {
      columns: [{
        text: '浙江',
        children: [{
          text: '温州温州温州温州温州温州温州-杭州',
          children: [{ text: '西湖区' }, { text: '余杭区' }],
        }, {
          text: '温州温州温州温州温州温州温州-温州',
          children: [{ text: '鹿城区' }, { text: '瓯海区' }],
        }]
      }]
    }
  },
  methods: {
    checkScroll () {
      this.$nextTick(() => {
        // 获取选中元素
        let selectedItems = [...document.querySelectorAll('.van-picker-column__item--selected')]
        selectedItems.forEach(item => {
          let child = item.querySelector('.van-ellipsis')
          if (child.offsetWidth > item.offsetWidth) { // 判断child文字宽度
            item.classList.add('scroll')
          } else {
            item.classList.remove('scroll')
          }
        })
      })
    }
  }
}
</script>
<style lang="less" scoped>
/deep/ .van-picker-column__item--selected {
  /* 重写选中后的效果 */
  .van-ellipsis {
    text-overflow: unset;
    overflow: visible;
  }
  /* 增加scroll类 */
  &.scroll > .van-ellipsis {
    animation: move 4s linear infinite;
  }
}
@keyframes move {
  0% { transform: translateX(100%); }
  100% { transform: translateX(-100%); }
}
</style>

这样,当滚动picker选中文字超长的时候,选中项就会出现滚动效果。

vant_picker_选择器(搭配弹出层使用)

<van-field
  readonly
  clickable
  label="城市"
  :value="value"
  placeholder="选择城市"
  @click="showPicker = true"
/>
<van-popup v-model="showPicker" round position="bottom">
  <van-picker
    show-toolbar
    :columns="columns"
    value-key="name" 
    @cancel="showPicker = false"
    @confirm="onConfirm"
  />
</van-popup>
<!--
重点:自定义value-key属性:默认值是text
value-key这个属性是自定义后台返回字段作为选择器显示的内容,这样后台返回的字段位未name时,也可以显示了。
否则默认的原始对象默认是[{text:'选项一',value:'1'},{text:'选项二',value:'2'}]
-->

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

相关文章

  • webpack中的optimization配置示例详解

    webpack中的optimization配置示例详解

    这篇文章主要介绍了webpack中的optimization配置详解,主要就是根据不同的策略来分割打包出来的bundle,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2023-02-02
  • 深入了解Vue2中的的双端diff算法

    深入了解Vue2中的的双端diff算法

    双端Diff在可以解决更多简单Diff算法处理不了的场景,且比简单Diff算法性能更好。本文主要来和大家详细讲讲Vue2中的双端diff算法的实现与使用,需要的可以参考一下
    2023-02-02
  • vue+elementUI多表单同时提交及表单校验最新解决方案

    vue+elementUI多表单同时提交及表单校验最新解决方案

    假设有一个页面,需要分三步填写三个表单,且每个表单位于独立的组件中,然后最后保存同时提交,如何进行表单必填项校验,下面小编给大家介绍vue+elementUI多表单同时提交及表单校验最新解决方案,感兴趣的朋友一起看看吧
    2024-03-03
  • Vue中Video标签播放解析后短视频去水印无响应解决

    Vue中Video标签播放解析后短视频去水印无响应解决

    这篇文章主要为大家介绍了Vue中使用Video标签播放 <解析后的短视频>去水印视频无响应的解决方式,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2022-04-04
  • vue大型项目之分模块运行/打包的实现

    vue大型项目之分模块运行/打包的实现

    这篇文章主要介绍了vue大型项目之分模块运行/打包的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-09-09
  • 使用vue实现HTML页面生成图片的方法

    使用vue实现HTML页面生成图片的方法

    这篇文章主要介绍了使用vue实现HTML页面生成图片的相关知识,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2020-03-03
  • 浅谈Vue.nextTick 的实现方法

    浅谈Vue.nextTick 的实现方法

    本篇文章主要介绍了Vue.nextTick 的实现方法,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2017-10-10
  • vue3 组合式API defineEmits() 与 emits 组件选项详解

    vue3 组合式API defineEmits() 与 emits 组

    在Vue中,defineEmits()是Vue3组合式API中用于声明自定义事件的,而emits选项则用于Vue2和Vue3的选项式API中,defineEmits()允许使用字符串数组或对象形式声明事件,emits选项也支持这两种形式,且验证函数可以验证事件参数,这两种方法都是为了更规范地在组件间通信
    2024-09-09
  • Vue中@keyup.enter @v-model.trim的用法小结

    Vue中@keyup.enter @v-model.trim的用法小结

    这篇文章主要介绍了Vue中@keyup.enter @v-model.trim的用法,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2023-12-12
  • 解决Vue开发中对话框被遮罩层挡住的问题

    解决Vue开发中对话框被遮罩层挡住的问题

    在Vue的开发中,一旦我们用到对话框,经常出现的问题是对话框被遮罩层挡住,怎么来解决这个问题呢?下面小编给大家带来了Vue开发中对话框被遮罩层挡住的问题及解决方法,一起看看吧
    2018-11-11

最新评论