栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > Web开发 > JavaScript

javascript单张多张图无缝滚动实例代码

JavaScript 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

javascript单张多张图无缝滚动实例代码

我们会看到很多的网站上会使用多张图片无缝滚动的效果。

下面我就介绍几种纯JS实现多张图片的无缝滚动,并实现鼠标移到图片上运动停止的效果,可以控制图片左右滚动。

1.效果展示:




	无缝滚动


*{margin: 0;padding: 0;}
	#div1{position: relative;border:1px solid #0ff;width:1100px; height: 180px;margin:50px auto 0;overflow: hidden;}
	#div1 ul{position: absolute;left: 0;}
	#div1 ul li{list-style: none;width:200px;float: left;padding: 10px;height: 160px;}
	#div1 ul li img{width:100%;}



	←
	→

	

 

内容补充:

背景:

想要实现图片持续滚动,既然使用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)
  }
}

以上就是javascript单张多张图无缝滚动实例代码的详细内容,更多关于javascript图片无缝滚动的资料请关注考高分网其它相关文章!

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/70388.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号