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+element_ui上传文件,并传递额外参数操作
Dec 05 Vue.js
Vue过滤器,生命周期函数和vue-resource简单介绍
Jan 12 Vue.js
vue 中this.$set 动态绑定数据的案例讲解
Jan 29 Vue.js
详解vue3中组件的非兼容变更
Mar 03 Vue.js
vue2实现provide inject传递响应式
May 21 Vue.js
Vue提供的三种调试方式你知道吗
Jan 18 Vue.js
Vue.js中v-for指令的用法介绍
Mar 13 Vue.js
vue实现列表拖拽排序的示例代码
Apr 08 Vue.js
vue实现书本翻页动画效果实例详解
Apr 08 Vue.js
分享一个vue实现的记事本功能案例
Apr 11 Vue.js
vue的项目如何打包上线
Apr 13 Vue.js
Vue组件化(ref,props, mixin,.插件)详解
May 15 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
编写PHP脚本过滤用户上传的图片
2015/07/03 PHP
PHP实现合并两个排序链表的方法
2018/01/19 PHP
学习JS面向对象成果 借国庆发布个最新作品与大家交流
2009/10/03 Javascript
通过Javascript读取本地Excel文件内容的代码示例
2014/04/08 Javascript
js调试工具Console命令详解
2014/10/21 Javascript
使用jQuery实现验证上传图片的格式与大小
2014/12/03 Javascript
EasyUi datagrid 实现表格分页
2015/02/10 Javascript
jQuery弹出div层过2秒自动消失
2016/11/29 Javascript
js实现5秒倒计时重新发送短信功能
2017/02/05 Javascript
js实现九宫格的随机颜色跳转
2017/02/19 Javascript
Bootstrap Table使用整理(四)之工具栏
2017/06/09 Javascript
详解JS构造函数中this和return
2017/09/16 Javascript
浅谈angular4实际项目搭建总结
2017/12/01 Javascript
vue的一个分页组件的示例代码
2017/12/25 Javascript
vue2.0页面前进刷新回退不刷新的实现方法
2018/07/31 Javascript
vue 点击按钮实现动态挂载子组件的方法
2018/09/07 Javascript
WebGL学习教程之Three.js学习笔记(第一篇)
2019/04/25 Javascript
vue源码中的检测方法的实现
2019/09/26 Javascript
JS async 函数的含义和用法实例总结
2020/04/08 Javascript
详解vue中v-model和v-bind绑定数据的异同
2020/08/10 Javascript
vue设置全局访问接口API地址操作
2020/08/14 Javascript
深入理解python中的select模块
2017/04/23 Python
Python机器学习之决策树算法实例详解
2017/12/06 Python
python 获取指定文件夹下所有文件名称并写入列表的实例
2018/04/23 Python
Pycharm及python安装详细步骤及PyCharm配置整理(推荐)
2020/07/31 Python
只要五步 就可以用HTML5/CSS3快速制作便签贴特效(图)
2012/06/04 HTML / CSS
万豪国际住宅与别墅集团:Homes & Villas by Marriott International
2020/10/08 全球购物
更夫岗位责任制
2014/02/11 职场文书
销售人员工作自我评价
2014/09/21 职场文书
房屋产权共有协议书范本
2014/11/03 职场文书
2015年档案管理工作总结
2015/04/08 职场文书
消防安全月活动总结
2015/05/08 职场文书
单位更名证明
2015/06/18 职场文书
2015年幼儿园国庆节活动总结
2015/07/30 职场文书
Python爬虫进阶之Beautiful Soup库详解
2021/04/29 Python
elasticSearch-api的具体操作步骤讲解
2021/06/28 Java/Android