vue notice消息通知往上无限滚动效果

1.html


      <ul class="new-list" :class="{anim:animate}" @mouseenter="stop" @mouseleave="up">
            <li v-for="(item, i) in noticeList" :key="i" style="fontSize:.28rem;">
             {{item.val}}
            </li>
      </ul>

2.js

 noticeList: [
        {
          val: 123
        },
        {
          val: 1234
        },
        {
          val: 12345
        },
      ],
 mounted () {
    this.scrollUp()
  },
 methods: {
    scrollUp () {
      this.intNum = setInterval(() => {
        this.animate = true// 向上滚动的时候需要添加css3过渡动画
        setTimeout(() => {
          this.noticeList.push(this.noticeList[0])// 将数组的第一个元素添加到数组的
          this.noticeList.shift() // 删除数组的第一个元素
          this.animate = false
        }, 500)
      }, 3000)
    },
    // 鼠标移上去停止
    stop () {
      clearInterval(this.intNum)
    },
    up () {
      this.scrollUp()
    }



css
 .new-list{
        line-height: 28px;
        transition: top 0.5s;
    }
    .anim{
        transition: all 0.5s;
        margin-top: -28px;//高度等于行高
    }

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值