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 相关文章推荐
javascript 特殊字符串
Feb 25 Javascript
可以用鼠标拖动的DIV实现思路及代码
Oct 21 Javascript
jquery实现submit提交表单
Feb 03 Javascript
深入讲解AngularJS中的自定义指令的使用
Jun 18 Javascript
Angular ng-class详解及实例代码
Sep 19 Javascript
老生常谈Javascript中的原型和this指针
Oct 09 Javascript
jQuery ajax动态生成table功能示例
Jun 14 jQuery
Node.js利用js-xlsx处理Excel文件的方法详解
Jul 05 Javascript
vue-cli3.0 环境变量与模式配置方法
Nov 08 Javascript
vuex页面刷新后数据丢失的方法
Jan 17 Javascript
layer.open的自适应及居中及子页面标题的修改方法
Sep 05 Javascript
简单了解vue中的v-if和v-show的区别
Oct 08 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 microtime获取浮点的时间戳
2010/02/21 PHP
PHP入门教程之表单与验证实例详解
2016/09/11 PHP
精通JavaScript 纠正 cleanWhitespace函数
2010/03/11 Javascript
js控制iframe的高度/宽度让其自适应内容
2014/04/09 Javascript
分享一则javascript 调试技巧
2015/01/02 Javascript
JS实现向表格中动态添加行的方法
2015/03/30 Javascript
JavaScript中创建对象的模式汇总
2016/04/19 Javascript
如何用JavaScript实现动态修改CSS样式表
2016/05/20 Javascript
轻松掌握JavaScript代理模式
2016/08/26 Javascript
什么是JavaScript中的结果值?
2016/10/08 Javascript
vue 2.0组件与v-model详解
2017/03/27 Javascript
Vue.js实现图片的随意拖动方法
2018/03/08 Javascript
使用vue-router为每个路由配置各自的title
2018/07/30 Javascript
vue打包之后生成一个配置文件修改接口的方法
2018/12/09 Javascript
JavaScript实现多球运动效果
2020/09/07 Javascript
Vue中正确使用Element-UI组件的方法实例
2020/10/13 Javascript
JavaScript/TypeScript 实现并发请求控制的示例代码
2021/01/18 Javascript
Python微信公众号开发平台
2018/01/25 Python
DataFrame中去除指定列为空的行方法
2018/04/08 Python
python读取图片的方式,以及将图片以三维数组的形式输出方法
2019/07/03 Python
Pyspark获取并处理RDD数据代码实例
2020/03/27 Python
在脚本中单独使用django的ORM模型详解
2020/04/01 Python
如何表示python中的相对路径
2020/07/08 Python
纯css3实现照片墙效果
2014/12/26 HTML / CSS
美国最好的保健品打折网店:Swanson
2017/08/04 全球购物
铭宣海淘转运:美国、日本、英国转运等全球转运公司
2019/09/10 全球购物
SQL Server提供的3种恢复模型都是什么? 有什么区别?
2012/05/13 面试题
品恩科技软件测试面试题
2014/10/26 面试题
护理专科毕业自荐信范文
2014/04/21 职场文书
大学班级文化建设方案
2014/05/06 职场文书
自强之星事迹材料
2014/05/12 职场文书
高校群众路线教育实践活动剖析材料
2014/10/10 职场文书
综合测评自我评价
2015/03/06 职场文书
2015年幼儿园中班下学期工作总结
2015/05/22 职场文书
个人工作总结(管理人员)范文
2019/08/13 职场文书
nginx前后端同域名配置的方法实现
2021/03/31 Servers