JS实现单张或多张图片持续无缝滚动的示例代码


Posted in Javascript onMay 10, 2020

背景:

想要实现图片持续滚动,既然使用js,就千万不要加css动画、过渡等相关样式,如果想要滚动的平滑一下,可以一像素一像素的感动,则很平滑,如果加了过渡动画,当图片重置为0时,会有往回倒的动画效果,跟预期不符。

原理:

图片滚动原理同图片轮播原理,同样也适用于文字滚动等一系列滚动,通过复制最后一张图片或最后一堆文字插入第一行,或复制第一张图片或一堆文字插入在结尾,来实现无缝拼接,前提:1、必须是没有设置过渡动画的,2、重置为0的时候与当前已经滚动到的高度对于图片的位置而言肉眼看上去没变化。

实现:

html主要包含三块:

1、最外层盒子,用来展示滚动图的区域,overflow:hidden;

2、滚动的盒子,主要改变该盒子的定位值,来实现滚动,里面包含所有要滚动的图片或文字

3、包含图片或文字的盒子。

代码:

class Roll {
  constructor(opts) {
    this.elem = opts.elem; // 图片包含滚动长度的元素的
    this.elemBox = opts.elemBox; //图片展示区域元素,为了获取展示区域的高度
    this.direction = opts.direction;
    this.time = opts.time;
    this.init();
    this.roll = this.roll.bind(this)
    this.startRoll = this.startRoll.bind(this)
    this.stopRoll = this.stopRoll.bind(this)
  }
  init(){
    this.elemHeight = this.elem.offsetHeight;
    this.elemHtml = this.elem.innerHTML;
    this.elem.innerHTML = this.elem.innerHTML + this.elemHtml+ this.elemHtml;
    this.speed;
    // 如果向上滚或者向左滚动每次减1,向下滚或者向右滚动每次加1
    if(this.direction === 'top' || this.direction === 'left'){
      this.speed = -1;
    }else{
      this.speed = 1;
    }
  }
  roll(){
    switch (this.direction) {
      case "top":
        // 如果滚动的盒子的top值超出元素的高度,则置为0
        if(Math.abs(this.elemBox.offsetTop) >= this.elemHeight){
          this.elemBox.style.top = 0;
        }else{
          this.elemBox.style.top = this.elemBox.offsetTop + this.speed + 'px';
        }
        break;
      case "bottom":
        // 如果滚动的盒子的bottom值超出元素的高度,则置为0
        if(Math.abs(this.elemBox.offsetBottom) >= this.elemHeight){
          this.elemBox.style.bottom = 0;
        }else{
          this.elemBox.style.bottom = this.elemBox.offsetBottom + this.speed + 'px';
        }
        break;
      case "left":
        // 如果滚动的盒子的left超出元素的高度,则置为0
        if(Math.abs(this.elemBox.offsetLeft) >= this.elemHeight){
          this.elemBox.style.left = 0;
        }else{
          this.elemBox.style.left = this.elemBox.offsetLeft + this.speed + 'px';
        }
        break;
      case "right":
        // 如果滚动的盒子的right超出元素的高度,则置为0
        if(Math.abs(this.elemBox.offsetRight) >= this.elemHeight){
          this.elemBox.style.right = 0;
        }else{
          this.elemBox.style.right = this.elemBox.offsetRight + this.speed + 'px';
        }
        break;
      default:
        // 默认向上滚动,如果滚动的盒子的top超出元素的高度,则置为0
        if(Math.abs(this.elemBox.offsetTop) >= this.elemHeight){
          this.elemBox.style.top = 0;
        }else{
          this.elemBox.style.top = this.elemBox.offsetTop + speed + 'px';
        }
    }
  }
  stopRoll(){
    clearInterval(this.scrollTimer)
  }
  startRoll(){
    this.scrollTimer = setInterval(this.roll,this.time)
  }
}

参考链接:

https://www.teakki.com/p/590beb7be8136dfc5f21770d

总结

到此这篇关于JS实现单张或多张图片持续无缝滚动的文章就介绍到这了,更多相关js 图片 无缝滚动内容请搜索三水点靠木以前的文章或继续浏览下面的相关文章希望大家以后多多支持三水点靠木!

Javascript 相关文章推荐
js+css使DIV始终居于屏幕中间 左下 左上 右上 右下的代码集合
Mar 10 Javascript
javascript实现日历控件(年月日关闭按钮)
Dec 12 Javascript
原生javascript实现的分页插件pagenav
Aug 28 Javascript
node.js中的fs.createWriteStream方法使用说明
Dec 17 Javascript
jsonp跨域请求数据实现手机号码查询实例分析
Dec 12 Javascript
js当前页面登录注册框,固定div,底层阴影的实例代码
Oct 04 Javascript
JS 滚动事件window.onscroll与position:fixed写兼容IE6的回到顶部组件
Oct 10 Javascript
Vue.js开发环境搭建
Nov 10 Javascript
express+mockjs实现模拟后台数据发送功能
Jan 07 Javascript
100行代码实现一个vue分页组功能
Nov 06 Javascript
Vue CL3 配置路径别名详解
May 30 Javascript
小程序点击图片实现png转jpg
Oct 22 Javascript
Layer UI表格列日期格式化及取消自动填充日期的实现方法
May 10 #Javascript
angula中使用iframe点击后不执行变更检测的问题
May 10 #Javascript
JavaScript 装逼指南(js另类写法)
May 10 #Javascript
js中!和!!的区别与用法
May 09 #Javascript
JS端基于download.js实现图片、视频时直接下载而不是打开预览
May 09 #Javascript
JS 获取文件后缀,判断文件类型(比如是否为图片格式)
May 09 #Javascript
js根据后缀判断文件文件类型的代码
May 09 #Javascript
You might like
PHP中单引号与双引号的区别分析
2014/08/19 PHP
CI框架学习笔记(一) - 环境安装、基本术语和框架流程
2014/10/26 PHP
php根据一个给定范围和步进生成数组的方法
2015/06/19 PHP
详解PHP错误日志的获取方法
2015/07/20 PHP
php输出含有“#”字符串的方法
2017/01/18 PHP
javascript Select标记中options操作方法集合
2008/10/22 Javascript
基于jQuery的input输入框下拉提示层(自动邮箱后缀名)
2012/06/14 Javascript
javascript学习笔记(七)Ajax和Http状态码
2014/10/08 Javascript
jquery制作 随机弹跳的小球特效
2015/02/01 Javascript
实例讲解JavaScript中call、apply、bind方法的异同
2016/09/13 Javascript
BootStrap中Table分页插件使用详解
2016/10/09 Javascript
jQuery 实现图片的依次加载图片功能
2017/07/06 jQuery
vue router使用query和params传参的使用和区别
2017/11/13 Javascript
详解Angular调试技巧之报错404(not found)
2018/01/31 Javascript
vue路由导航守卫和请求拦截以及基于node的token认证的方法
2019/04/07 Javascript
微信小程序实现同一页面取值的方法分析
2019/04/30 Javascript
Vue.js+cube-ui(Scroll组件)实现类似头条效果的横向滚动导航条
2019/06/24 Javascript
关于layui时间回显问题的解决方法
2019/09/24 Javascript
解决小程序无法触发SESSION问题
2020/02/03 Javascript
微信小程序中使用 async/await的方法实例分析
2020/05/06 Javascript
使用python实现个性化词云的方法
2017/06/16 Python
pycharm重置设置,恢复默认设置的方法
2018/10/22 Python
Python模块、包(Package)概念与用法分析
2019/05/31 Python
Django url,从一个页面调到另个页面的方法
2019/08/21 Python
python使用socket 先读取长度,在读取报文内容示例
2019/09/26 Python
python数值基础知识浅析
2019/11/19 Python
python如何绘制疫情图
2020/09/16 Python
CSS3实现可关闭的下拉手风琴菜单效果
2015/08/31 HTML / CSS
苏宁红孩子母婴商城:redbaby
2017/02/12 全球购物
中专毕业生求职简历的自我评价
2013/10/21 职场文书
大学生的四年学习自我评价
2013/12/13 职场文书
普通党员四风问题对照检查材料
2014/09/27 职场文书
个人工作违纪检讨书
2015/05/05 职场文书
2015年民兵整组工作总结
2015/07/24 职场文书
导游词之广东佛山(南风古灶)
2019/09/24 职场文书
告别网页搜索!教你用python实现一款属于自己的翻译词典软件
2021/06/03 Python