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列表滚动的资料请关注脚本之家其它相关文章!

相关文章

  • element表单验证如何清除校验提示语

    element表单验证如何清除校验提示语

    本文主要介绍了element表单验证如何清除校验提示语,文中通过示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2021-10-10
  • Vuex Actions多参数传递的解决方案

    Vuex Actions多参数传递的解决方案

    在 Vuex 中,actions 的设计默认只支持单个参数传递,这有时会限制我们的使用场景,下面我将详细介绍几种处理多参数传递的解决方案,从基础到高级,帮助您灵活应对各种需求,需要的朋友可以参考下
    2025-04-04
  • Vue Mock.js介绍和使用与首页导航栏左侧菜单搭建过程

    Vue Mock.js介绍和使用与首页导航栏左侧菜单搭建过程

    Mock.js是一个模拟数据的生成器,用来帮助前端调试开发、进行前后端的原型分离以及用来提高自动化测试效率,这篇文章主要介绍了Vue Mock.js介绍和使用与首页导航栏左侧菜单搭建,需要的朋友可以参考下
    2023-09-09
  • vue实现选中效果

    vue实现选中效果

    本文给大家分享的是如何使用vue实现鼠标点击选中的效果,附上了实例代码,有需要的小伙伴可以参考下
    2020-10-10
  • 详解vue前后台数据交互vue-resource文档

    详解vue前后台数据交互vue-resource文档

    本篇文章主要介绍了vue前后台数据交互vue-resource文档,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2017-07-07
  • 关于vue 的slot分发内容 (多个分发)

    关于vue 的slot分发内容 (多个分发)

    这篇文章主要介绍了关于vue 的slot分发内容 (多个分发),具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-03-03
  • 如何在Vue项目中应用TypeScript类

    如何在Vue项目中应用TypeScript类

    与如何在React项目中应用TypeScript类类似在VUE项目中应用typescript,我们需要引入一个库vue-property-decorator,需要的小伙伴可续看下文具体介绍
    2021-09-09
  • vue+echarts实现动态绘制图表及异步加载数据的方法

    vue+echarts实现动态绘制图表及异步加载数据的方法

    vue写的后台管理,需要将表格数据绘制成图表(折线图,柱状图),图表数据都是通过接口请求回来的。这篇文章主要介绍了vue+echarts 动态绘制图表及异步加载数据的相关知识,需要的朋友可以参考下
    2018-10-10
  • 浅谈在不使用ssr的情况下解决Vue单页面SEO问题(2)

    浅谈在不使用ssr的情况下解决Vue单页面SEO问题(2)

    这篇文章主要介绍了浅谈在不使用ssr的情况下解决Vue单页面SEO问题(2),小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2018-11-11
  • vue执行配置选项npm run serve的本质图文详解

    vue执行配置选项npm run serve的本质图文详解

    本地开发一般通过执行npm run serve命令来启动项目,那这行命令到底存在什么魔法?下面这篇文章主要给大家介绍了关于vue执行配置选项npm run serve的本质的相关资料,需要的朋友可以参考下
    2023-05-05

最新评论