vue实现轮播图帧率播放


Posted in Vue.js onJanuary 26, 2021

本文实例为大家分享了vue实现轮播图帧率播放的具体代码,供大家参考,具体内容如下

需求

传入一个数组,数组中放的是目录名称,通过本目录名称,读取文件目录下的所有图片,并循环播放,形成一个每1s播放多少张图片的效果,最后目录播放完毕后,在跳到第一个目录循环播放。

核心: 用 webpack的一个API require.contex读取目录下的文件名,具体想了解的可以查一查。

代码

HTML

<template>
 <div id="imgPlay" ref="container" :style="[style]">
 <img :src="imgsrc" :style="[{height:style.height,width:style.width}]">
 <div id="but">
  <button @click="start()">开始</button>
  <button @click="stop()">停止</button>
 </div>
 </div>
</template>

javascript

<script>
export default {
 name: 'ZxImgPlay',
 data () {
 return {
  style:[
 width:"50px",
 height:"50px"
 ],
  interval: null, // 定时器id
  flag: true, // 定时器的开关
  setIntervalNumber: 0, // 当前展示的图片下标
  imgsrc: "", // 要展示的图片路径
  imgUrls: [], // 所有的图片路径
  frameRate: 0 // 帧率
 }
 },
 computed: {},
 watch: {},
 created () { },
 mounted () {
 this.zxInit()
 },
 beforeDestroy () { },

 methods: {
 zxInit () {
 // 这里的 this.DisplayParam 是公司内部的一套东西,混入的对象
 // this.DisplayParam.frameRate 是一个数组["目录名1","目录名2"]
 // this.DisplayParam.imgUrls 是死图当没有目录的时候就用死图
 // this.DisplayParam.frameRate 是传入的帧率
  this.frameRate = this.DisplayParam.frameRate && (1000 / this.DisplayParam.frameRate)
  this.imgUrls = this.DisplayParam.imgUrls
  this.DisplayParam.imageFileName != 0 ? this.readdir(this.DisplayParam.imageFileName) : this.showImages(true)
 },

 start () {
  if (this.flag) return
  this.showImages()
  this.flag = true
 },

 stop () {
  this.flag = false
  clearInterval(this.interval)
 },

 readImages (imageFileName, _A) {
  this.stop()
  let req = require.context("@/../static/images", true, /\.(?:bmp|jpg|gif|jpeg|png)$/).keys();
  let path = new RegExp(imageFileName[_A])
  req.forEach(item => {
  if (path.test(item)) {
   this.imgUrls.push({ img: "@/../static/images/" + imageFileName[_A] + item.substring(item.lastIndexOf('/')) })
  }
  })
  this.showImages()
 },
 readdir (imageFileName) {
  this.imgUrls = []
  for (let i = 0; i < imageFileName.length; i++) {
  this.readImages(imageFileName, i)
  }
 },

 showImages (_B) {
  if (_B) this.imgUrls = this.imgUrlsSort(this.imgUrls, 'sort')
  console.log(this.imgUrls)
  this.interval = setInterval(this.setIntervalFun, this.frameRate)
 },

 imgUrlsSort (ary, key) {
  return ary.sort((a, b) => {
  let x = a[key];
  let y = b[key];
  return ((x < y) ? -1 : (x > y) ? 1 : 0)
  })
 },

 setIntervalFun () {
  if (this.setIntervalNumber >= this.imgUrls.length) {
  this.setIntervalNumber = 0
  }
  this.imgsrc = this.imgUrls[this.setIntervalNumber++].img || ''
 }
 }
}
</script>

问题

上述这么做已经实现了功能,但是目前来说是发现了两个问题

1、require.context() 这个API它的第一个参数不能用一个可变的值,比如变量,会有警告。
2、上述代码一直更换图片的src实现的,也就是说每次换src时都会发送http请求获取图片,导致了内存不会被释放一直增加。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Vue.js 相关文章推荐
vue 获取到数据但却渲染不到页面上的解决方法
Nov 19 Vue.js
Vue.js桌面端自定义滚动条组件之美化滚动条VScroll
Dec 01 Vue.js
Vue 修改网站图标的方法
Dec 31 Vue.js
基于VUE实现简单的学生信息管理系统
Jan 13 Vue.js
vscode自定义vue模板的实现
Jan 27 Vue.js
Vue 3自定义指令开发的相关总结
Jan 29 Vue.js
Vue 事件的$event参数=事件的值案例
Jan 29 Vue.js
vue 根据选择的月份动态展示日期对应的星期几
Feb 06 Vue.js
vue实现倒计时功能
Mar 24 Vue.js
使用Vue3+Vant组件实现App搜索历史记录功能(示例代码)
Jun 09 Vue.js
Vue的过滤器你真了解吗
Feb 24 Vue.js
vue3引入highlight.js进行代码高亮的方法实例
Apr 08 Vue.js
vue 组件基础知识总结
Jan 26 #Vue.js
深入了解Vue动态组件和异步组件
Jan 26 #Vue.js
如何在 Vue 表单中处理图片
Jan 26 #Vue.js
Vue实现摇一摇功能(兼容ios13.3以上)
Jan 26 #Vue.js
Vue中的nextTick作用和几个简单的使用场景
Jan 25 #Vue.js
Vue使用Ref跨层级获取组件的步骤
Jan 25 #Vue.js
如何在Vue项目中添加接口监听遮罩
Jan 25 #Vue.js
You might like
实现分十页分向前十页向后十页的处理
2006/10/09 PHP
15种PHP Encoder的比较
2007/03/06 PHP
Cakephp 执行主要流程
2010/03/24 PHP
调试PHP程序的多种方法介绍
2014/11/06 PHP
php的sso单点登录实现方法
2015/01/08 PHP
PHP单例模式模拟Java Bean实现方法示例
2018/12/07 PHP
禁止刷新,回退的JS
2006/11/25 Javascript
js confirm()方法的使用方法实例
2013/07/13 Javascript
js和php如何获取当前url的内容
2013/09/22 Javascript
AngularJS自动表单验证
2016/02/01 Javascript
jQuery EasyUI 入门必看
2016/06/03 Javascript
利用Node.js制作爬取大众点评的爬虫
2016/09/22 Javascript
jQuery通过ajax方法获取json数据不执行success的原因及解决方法
2016/10/15 Javascript
bootstrap为水平排列的表单和内联表单设置可选的图标
2017/02/15 Javascript
微信小程序 可搜索的地址选择实现详解
2019/08/28 Javascript
js 图片懒加载的实现
2020/10/21 Javascript
[56:47]Ti4 循环赛第三日 iG vs Liquid
2014/07/12 DOTA
Python方法的延迟加载的示例代码
2017/12/18 Python
实例详解python函数的对象、函数嵌套、名称空间和作用域
2019/05/31 Python
Window10下python3.7 安装与卸载教程图解
2019/09/30 Python
pygame实现俄罗斯方块游戏(AI篇2)
2019/10/29 Python
Python生成个性签名图片获取GUI过程解析
2019/12/16 Python
对tensorflow中tf.nn.conv1d和layers.conv1d的区别详解
2020/02/11 Python
python3.9和pycharm的安装教程并创建简单项目的步骤
2021/02/03 Python
html5 自定义播放器核心代码
2013/12/20 HTML / CSS
英国第一蛋白粉品牌:Myprotein
2016/09/14 全球购物
巴西香水和化妆品购物网站:The Beauty Box
2019/09/03 全球购物
高级Java程序员面试要点
2013/08/02 面试题
Servlet如何得到服务器的信息
2015/12/22 面试题
硕士毕业论文导师评语
2014/12/31 职场文书
学生会个人总结范文
2015/02/15 职场文书
无工作证明怎么写
2015/06/15 职场文书
导游词之麻姑仙境
2019/11/18 职场文书
导游词之开封禹王台风景区
2019/12/02 职场文书
CSS3中Animation实现简单的手指点击动画的示例
2021/07/15 HTML / CSS
速龙x4-860k处理器相当于i几
2022/04/20 数码科技