Vue 实现简易多行滚动"弹幕"效果


Posted in Javascript onJanuary 02, 2020

看一下效果:

Vue 实现简易多行滚动"弹幕"效果 

实现任意行数的定时翻滚效果,不使用重复标签的方式,而是根据展示个数判断是否缺省,并添加对应展示个数的重复项来实现。

Vue 的演示代码如下:

<template>
 <div class="demo-comment-container">
 <div
  class="scroll-container"
  :style="{height: `${height/100}rem`}"
 >
  <ul
  class="scroll-ul"
  :style="{transform: `translate3d(0, ${y/100}rem, 0)`, transition: `${transition}`}"
  >
  <div
   v-for="(item, index) in list"
   :key="index"
   v-bind="baseStyle.style"
   :bgColor="baseStyle.style.bgColor__bg"
   :style="{ color: rgba(baseStyle.color__nf) }"
   :class="['c-item-bg', 'c-item', !item.content && 'empty']"
  >
   <li
   class="c-item"
   >
   <div class="avatar">
    <img
    v-if="item.content"
    class="avatar-item"
    :src="item.photo"
    >
   </div>
   <div
    v-if="item.content"
    class="c-content"
    v-html="item.content"
   />
   </li>
  </div>
  </ul>
 </div>
 <div class="comment-entry">
  <div class="f">
  <div class="text-c">
   <span
   v-if="entry.type === 1"
   class="text"
   v-text="entry.text"
   />
   <div
   v-else
   class="img-container"
   >
   <img :src="entry.image">
   </div>
   <i
   v-if="count"
   class="c-c"
   >{{ count }}</i>
  </div>
  <div>
   <span class="fake-input">来发表你的看法吧~</span>
  </div>
  </div>
 </div>
 </div>
</template>
<script>
export default {
 inject: ['rgba'],
 props: {
 urlConfig: {
  type: Object,
  default: function () {
  return {}
  }
 },
 type: {
  type: String,
  default: 'hot'
 },
 pageSize: {
  type: Number,
  default: 50
 },
 open: {
  type: Boolean,
  default: true
 },
 entry: {
  type: Object,
  default: function () {
  return {
   type: 1, // 1 文字 2 自定义
   text: '',
   image: ''
  }
  }
 },
 number: {
  type: Number,
  default: 2
 },
 },
 data () {
 return {
  count: 2334,
  dom: null,
  height: 0, // 单项高度
  y: 0, // 每次移动距离
  list: [], // 接口列表
  originLength: 0, // 原始数组长度
  transition: 'ease all .4s',
  round: 0 // 需要滚动多少轮
 }
 },
 created () {
 this.getCommentList()
 },
 mounted () {
 this.dom = document.querySelector('.c-item')
 // 计算可视区域高度
 this.height = 64 * this.number + (12 * (this.number - 1))
 },
 methods: {
 getCommentList () {
  // 接口数据
  const _list = []
  this.originLength = _list.length
  const mod = this.originLength % this.number
  let need = this.originLength < this.number ? (this.number - this.originLength) : mod > 0 ? this.number - mod : 0 // 计算出要添加的空白元素个数
  this.list = _list

  // set empty item
  const empty = JSON.parse(JSON.stringify(_list[0]))
  empty.content = ''

  // 补齐空白元素
  while (need) {
  this.list.push(empty)
  need--
  }

  // 填充重复元素
  let repeat = this.number
  let index = 0
  while (repeat) {
  this.list.push(_list[index])
  index++
  repeat--
  }

  this.round = this.list.length / this.number

  this.scroll()
 },
 scroll () {
  let count = 1
  setInterval(() => {
  count++
  this.y -= this.height + 12 // 移动可视区域高度 + 最后一个 item 的 margin-bottom
  this.transition = '.4s ease all'
  setTimeout(() => {
   if (count === this.round) {
   count = 1
   this.transition = ''
   this.y = 0
   }
  }, 800)
  }, 2000)
 }
 }
}
</script>

总结

以上所述是小编给大家介绍的Vue 实现简易多行滚动"弹幕",希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对三水点靠木网站的支持!
如果你觉得本文对你有帮助,欢迎转载,烦请注明出处,谢谢!

Javascript 相关文章推荐
js href的用法
May 13 Javascript
发布一个基于javascript的动画类 Fx.js
Nov 05 Javascript
JS连接SQL数据库与ACCESS数据库的方法实例
Nov 21 Javascript
动态添加option及createElement使用示例
Jan 26 Javascript
jQuery模拟select实现下拉菜单功能
Jun 20 Javascript
JS防止网页被嵌入iframe框架的方法分析
Sep 13 Javascript
node.js中express中间件body-parser的介绍与用法详解
May 23 Javascript
Angularjs自定义指令Directive详解
May 27 Javascript
Vue.js列表渲染绑定jQuery插件的正确姿势
Jun 29 jQuery
详解React Native顶|底部导航使用小技巧
Sep 14 Javascript
小程序红包雨的实现示例
Feb 19 Javascript
Vue中Table组件Select的勾选和取消勾选事件详解
Mar 19 Javascript
JS实现秒杀倒计时特效
Jan 02 #Javascript
在weex中愉快的使用scss的方法步骤
Jan 02 #Javascript
JS实现导航栏楼层特效
Jan 01 #Javascript
JS实现旋转木马轮播图
Jan 01 #Javascript
JS实现普通轮播图特效
Jan 01 #Javascript
javascript实现超好看的3D烟花特效
Jan 01 #Javascript
JavaScript工具库MyTools详解
Jan 01 #Javascript
You might like
PHP中Date()时间日期函数的使用方法小结
2011/04/20 PHP
解析PHP函数array_flip()在重复数组元素删除中的作用
2013/06/27 PHP
掌握PHP垃圾回收机制详解
2019/03/13 PHP
php输出控制函数和输出函数生成静态页面
2019/06/27 PHP
Laravel timestamps 设置为unix时间戳的方法
2019/10/11 PHP
Add Formatted Data to a Spreadsheet
2007/06/12 Javascript
JavaScript DOM 学习第二章 编辑文本
2010/02/19 Javascript
ExtJS4 Grid改变单元格背景颜色及Column render学习
2013/02/06 Javascript
利用javascript数组长度循环数组内所有元素
2013/12/27 Javascript
JQuery的Ajax请求实现局部刷新的简单实例
2014/02/11 Javascript
jQuery实现提示密码强度的代码
2015/07/15 Javascript
javascript实现网站加入收藏功能
2015/12/16 Javascript
学JavaScript七大注意事项【必看】
2016/05/04 Javascript
jQuery progressbar通过Ajax请求实现后台进度实时功能
2016/10/11 Javascript
Node调用Java的示例代码
2017/09/20 Javascript
JS简单生成由字母数字组合随机字符串示例
2018/05/25 Javascript
解决vue-cli单页面手机应用input点击手机端虚拟键盘弹出盖住input问题
2018/08/25 Javascript
微信小程序 Storage更新详解
2019/07/16 Javascript
Vue 实现点击空白处隐藏某节点的三种方式(指令、普通、遮罩)
2019/10/23 Javascript
RxJS在TypeScript中的简单使用详解
2020/04/13 Javascript
微信小程序实现watch监听
2020/06/04 Javascript
解决Vue 移动端点击出现300毫秒延迟的问题
2020/07/21 Javascript
Vue项目开发常见问题和解决方案总结
2020/09/11 Javascript
python 测试实现方法
2008/12/24 Python
Python守护进程(daemon)代码实例
2015/03/06 Python
Python中List.count()方法的使用教程
2015/05/20 Python
Python的多态性实例分析
2015/07/07 Python
Windows和Linux下Python输出彩色文字的方法教程
2017/05/02 Python
flask + pymysql操作Mysql数据库的实例
2017/11/13 Python
用Python写一段用户登录的程序代码
2018/04/22 Python
python时间time模块处理大全
2020/10/25 Python
Python绘制K线图之可视化神器pyecharts的使用
2021/03/02 Python
森马旗舰店双十一营销方案
2014/09/29 职场文书
消费者投诉书范文
2015/07/02 职场文书
大学生党员暑假实践(活动总结)
2019/08/21 职场文书
MongoDB修改oplog大小的四种方法
2022/04/11 MongoDB