vue实现消息列表向上无缝滚动效果

 更新时间:2024年06月02日 08:38:50   作者:小蹦跶儿  
本文主要实现vue项目中,消息列表逐条向上无缝滚动,每条消息展示10秒后再滚动,为了保证用户能看清消息主题,未使用第三方插件,本文实现方法比较简约,需要的朋友可以参考下

一、背景

最近产品有个需求:后台系统的未读消息,在用户登陆后,将未读信息在右侧浮窗无缝滚动;不关闭时,间隔10秒逐级消失逐级上浮,每次只展示一条消息;支持手动关闭浮窗;支持单击浮窗打开相应消息。

二、需要实现的效果

三、实现思路

根据需求,准备采用CSS(transition)结合JS(setTimeout)的方案进行实现,因为功能比较简单,所以没有使用第三方插件,也方便自定义样式。

四、实现方法

  • 首先我们先实现样式,看下html的实现代码:

代码如下图:

<template>
  <div :class="{anim:animate}" @mouseenter="stop()" @mouseleave="up()" class="unreadMsg">
    <div class="news_name" v-for="(item, index) in newsList" :key="item.id" @click="handleDetail(item)">
      <div class="content">
        <div class="title">{{ item.title }}</div>
        <div class="des">{{ item.description }}</div>
      </div>
      <span @click="handleDelete(item, index)" class="close">
        <a-icon type="close" style="cursor: pointer" />
      </span>
    </div>
 </div>
</template>

注:我的项目是ant-vue框架,上面代码中用到一个关闭icon(a-icon)标签,可作替换。

  • 接下来是css的实现代码:
<style lang="less" scoped>
.unreadMsg {
  max-height: 132px;
  overflow: hidden;
  position: absolute;
  right: 0;
  top: 0;
  bottom: auto;
  margin-inline-end: 24px;

  .news_name {
    line-height: 30px;
    transition: top 0.5s;
    transition-delay: 10s;
    position: relative;

    .content {
      position: relative;
      width: 384px;
      margin-bottom: 40px;
      margin-inline-start: auto;
      padding: 20px 30px;
      overflow: hidden;
      word-wrap: break-word;
      background: #fff;
      border-radius: 8px;

      .title {
        padding-right: 12px;
        margin-bottom: 8px;
        color: rgba(0, 0, 0, 0.88);
        font-size: 16px;
        line-height: 1.5;
        overflow: hidden;
        white-space: nowrap;
        text-overflow: ellipsis;
      }

      .des {
        font-size: 14px;
        cursor: pointer;
        overflow: hidden;
        text-overflow: ellipsis;
        display: -webkit-box;
        -webkit-box-orient: vertical;
        -webkit-line-clamp: 2;
      }
    }

    .close {
      position: absolute;
      top: 20px;
      inset-inline-end: 24px;
      color: rgba(0, 0, 0, 0.45);
      outline: none;
      width: 22px;
      height: 22px;
      border-radius: 4px;
      transition: background-color 0.2s, color 0.2s;
      display: flex;
      align-items: center;
      justify-content: center;
    }
  }
}
.anim {
  transition: all 0.5s;
  margin-top: -110px;
}
</style>
  • 最后通过js实现各项功能:
  • 首先实现 每条消息间隔10秒逐级消失逐级上浮 功能:
// 滚动动画
scrollUp() {
  // 每个消息展示10s
  this.timer = setInterval(() => {
    this.animate = true // 向上滚动的时候需要添加动画
    setTimeout(() => {
      this.newsList.push(this.newsList[0])// 将数组的第一个元素添加到数组最后一个
      this.newsList.shift() // 删除数组的第一个元素
      this.animate = false
    }, 500)
  }, 10000)
},

需要注意到是,这个滚动动画的方法,需要在mounted生命周期中执行,在created生命周期中请求后端接口,获取未读消息的list数组。
另:此处的10s可根据自己项目需求进行调整。

  • 实现 单击浮窗打开相应消息 功能:
handleDetail(item) {
  this.$router.push({ name: 'noticeDetailService', params: { id: item.id } })
 },

这里只要点击对应的消息,跳转到这个消息具体的详情页即可。因为每个消息都会有自己对应的ID,不用多说,都懂。

  • 实现 手动关闭当前的消息 功能:
handleDelete(item, index) {
  this.newsList.splice(index, 1) // 删除数组的当前元素
},

此处主要考虑的问题是,有的消息用户不想点开看详情,也不想看它在轮播,想直接关掉。只需要删除数组中的当前元素即可。

  • 最后记得在beforeDestroy生命周期中清除计时器clearInterval

  • 下面将js的全部代码附上:

<script>
import { noticeSearch } from '../api/index.js'

export default {
  name: 'unreadMsg',
  data() {
    return {
      timer: null,
      animate: false,
      newsList: []
    }
  },
  created() {
    this.noticeSearch()
  },
  mounted() {
    this.scrollUp() // 开启滚动效果
  },
  beforeDestroy() {
    this.stop()
  },
  methods: {
    async noticeSearch () {
      const data = await noticeSearch({ size: -1 })
      this.newsList = data.list
    },
    // 查看公告详情
    handleDetail(item) {
      this.$router.push({ name: 'noticeDetailService', params: { id: item.id } })
    },
    handleDelete(item, index) {
      this.newsList.splice(index, 1) // 删除数组的当前元素
    },
    // 滚动动画
    scrollUp() {
      // 每个消息展示10s
      this.timer = setInterval(() => {
        this.animate = true // 向上滚动的时候需要添加动画
        setTimeout(() => {
          this.newsList.push(this.newsList[0])// 将数组的第一个元素添加到数组最后一个
          this.newsList.shift() // 删除数组的第一个元素
          this.animate = false
        }, 500)
      }, 10000)
    },
    // 鼠标移上去停止
    stop() {
      clearInterval(this.timer)
    },
    // 鼠标离开继续
    up() {
      this.scrollUp()
    }
  }
}
</script>

五、总结

功能虽简单,需要注意的点也很多,要记得在对应的生命周期做对应的操作。用到定时器的地方也要记得进行清除。

以上就是vue实现消息列表向上无缝滚动的详细内容,更多关于vue列表滚动的资料请关注脚本之家其它相关文章!

相关文章

  • vue对象或者数组中数据变化但是视图没有更新问题及解决

    vue对象或者数组中数据变化但是视图没有更新问题及解决

    这篇文章主要介绍了vue对象或者数组中数据变化但是视图没有更新问题及解决,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2024-07-07
  • Vue.js轮播图走马灯代码实例(全)

    Vue.js轮播图走马灯代码实例(全)

    这篇文章主要介绍了Vue.js轮播图走马灯,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2019-05-05
  • vue中datepicker的使用教程实例代码详解

    vue中datepicker的使用教程实例代码详解

    这篇文章主要介绍了vue-datepicker的使用,本文通过实例代码大家介绍的非常详细,具有一定的参考借鉴价值,需要的朋友可以参考下
    2019-07-07
  • Vue3解析学习handlers 模块

    Vue3解析学习handlers 模块

    这篇文章主要介绍了Vue3解析学习handlers 模块的相关资料,需要的朋友可以参考下
    2026-02-02
  • unplugin-svg-component优雅使用svg图标指南

    unplugin-svg-component优雅使用svg图标指南

    这篇文章主要为大家介绍了unplugin-svg-component优雅使用svg图标指南,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2023-03-03
  • vue的表单数据收集案例之基本指令和自定义指令详解

    vue的表单数据收集案例之基本指令和自定义指令详解

    收集表单数据可以使用这个v-model实现这个数据的绑定,但是在有些输入框中,还需要一些其他的指令搭配这个v-model指令结合使用,这篇文章主要介绍了vue的表单数据收集,基本指令和自定义指令,需要的朋友可以参考下
    2023-01-01
  • 在Vue.js应用中实现分布式搜索和全文搜索

    在Vue.js应用中实现分布式搜索和全文搜索

    分布式搜索和全文搜索在现代应用程序中变得越来越重要,因为它们可以帮助用户快速查找和检索大量数据,Elasticsearch是一种强大的分布式搜索引擎,本文将介绍如何在Vue.js应用程序中实现分布式搜索和全文搜索,以及如何与Elasticsearch集成,需要的朋友可以参考下
    2023-11-11
  • vue-cli 模式下安装 uni-ui的详细过程

    vue-cli 模式下安装 uni-ui的详细过程

    文章介绍uni-app中easycom自定义组件机制,通过路径规范和配置简化组件使用流程,无需手动注册和导入,重点说明npm安装uni-ui后需配置vue.config.js编译,支持按需打包和自动加载,提升开发效率,同时区分Vue/uvue优先级及组件类型兼容性,感兴趣的朋友一起看看吧
    2025-07-07
  • Vue input输入框中的值如何变成黑点问题

    Vue input输入框中的值如何变成黑点问题

    这篇文章主要介绍了Vue input输入框中的值如何变成黑点问题,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2023-04-04
  • Vue项目使用PostCSS做h5页面的屏幕适配的配置步骤

    Vue项目使用PostCSS做h5页面的屏幕适配的配置步骤

    PostCSS 是一个用 JavaScript 编写的工具,用于将 CSS 转换为另一种 CSS,在做h5页面的屏幕适配时,结合 PostCSS 的一些插件能轻松实现,下面以结合 postcss-pxtorem 插件为例,详细介绍配置步骤,需要的朋友可以参考下
    2025-02-02

最新评论