javascript实现的左右无缝滚动效果


Posted in Javascript onSeptember 19, 2016

本文实例讲述了javascript实现的左右无缝滚动效果。分享给大家供大家参考,具体如下:

前面介绍过图片左右滚动,不过图片是间歇性的一张一张滚动,今天介绍的是几张图片一起进行无缝滚动,这是一个常用的 js 效果。

<!DOCTYPE HTML>
<html lang="en-US">
<head>
  <meta charset="UTF-8">
  <title>无缝滚动——左右</title>
  <link rel="stylesheet" type="text/css" href="../css/base.css" media="all"/>
  <style type="text/css">
  #scroll{width:698px;height:108px;margin:50px auto 0;position:relative;overflow:hidden;}
  .btn_left{display:block;width:68px;height:68px;background:url(images/btn.jpg) no-repeat -70px -69px;position:absolute;top:20px;left:1px;z-index:1;}
  .btn_left:hover{background:url(images/btn.jpg) no-repeat -70px 0;}
  .btn_right{display:block;width:68px;height:68px;background:url(images/btn.jpg) no-repeat 1px -69px;position:absolute;top:20px;right:0;z-index:1;}
  .btn_right:hover{background:url(images/btn.jpg) no-repeat 1px 0;}
  #scroll .content{width:546px;height:108px;position:relative;overflow:hidden;margin:0 auto;}
  #scroll ul{position:absolute;}
  #scroll li{float:left;width:182px;height:108px;text-align:center;}
  #scroll li a:hover{position:relative;top:2px;}
  </style>
</head>
<body>
  <div id="scroll">
    <a href="javascript:;" class="btn_left"></a>
    <a href="javascript:;" class="btn_right"></a>
    <div class="content">
      <ul>
        <li><a href="#"><img src="images/1.jpg" width="178" height="108" alt=""/></a></li>
        <li><a href="#"><img src="images/2.jpg" width="178" height="108" alt=""/></a></li>
        <li><a href="#"><img src="images/3.jpg" width="178" height="108" alt=""/></a></li>
        <li><a href="#"><img src="images/4.jpg" width="178" height="108" alt=""/></a></li>
      </ul>
    </div>
  </div>
</body>
</html>
<script type="text/javascript">
window.onload = function(){
  var oDiv = document.getElementById('scroll');
  var oUl = oDiv.getElementsByTagName('ul')[0];
  var aLi = oDiv.getElementsByTagName('li');
  var aBtn = oDiv.getElementsByTagName('a');
  var speed = -1;
  var timer = null;
  oUl.innerHTML += oUl.innerHTML;
  oUl.style.width = aLi[0].offsetWidth * aLi.length + 'px';
  timer = setInterval(function(){
    oUl.style.left = oUl.offsetLeft + speed + 'px';
    if(oUl.offsetLeft < - oUl.offsetWidth / 2){
      oUl.style.left = '0';
    }else if(oUl.offsetLeft > 0){
      oUl.style.left = - oUl.offsetWidth / 2 + 'px';
    }
  },30);
  aBtn[0].onclick = function(){
    speed = -1;
  };
  aBtn[1].onclick = function(){
    speed = 1;
  };
  oUl.onmouseover = function(){
    clearInterval(timer);
  };
  oUl.onmouseout = function(){
    timer = setInterval(function(){
      oUl.style.left = oUl.offsetLeft + speed + 'px';
      if(oUl.offsetLeft < -oUl.offsetWidth / 2){
        oUl.style.left = '0';
      }else if(oUl.offsetLeft > 0){
        oUl.style.left = - oUl.offsetWidth / 2 + 'px';
      }
    },30);
  };
};
</script>

PS:如果想要改变移动速度,只需要改变 speed 的值。

希望本文所述对大家JavaScript程序设计有所帮助。

Javascript 相关文章推荐
Javascript实现的分页函数
Dec 22 Javascript
js中判断Object、Array、Function等引用类型对象是否相等
Aug 29 Javascript
javascript实现颜色渐变的方法
Oct 30 Javascript
JS常用表单验证方法总结
May 22 Javascript
jquery淡入淡出效果简单实例
Jan 14 Javascript
JavaScript_object基础入门(必看篇)
Jun 13 Javascript
js实现二级导航功能
Mar 03 Javascript
JS使用正则表达式找出最长连续子串长度
Oct 26 Javascript
基于three.js编写的一个项目类示例代码
Jan 05 Javascript
js实现滚动条自动滚动
Dec 13 Javascript
javascript实现随机抽奖功能
Dec 30 Javascript
element-ui封装一个Table模板组件的示例
Jan 04 Javascript
javascript实现图片左右滚动效果【可自动滚动,有左右按钮】
Sep 19 #Javascript
BootStrap入门教程(三)之响应式原理
Sep 19 #Javascript
HTML5 实现的一个俄罗斯方块实例代码
Sep 19 #Javascript
javascript this详细介绍
Sep 19 #Javascript
JS遍历ul下的li点击弹出li的索引的实现方法
Sep 19 #Javascript
vuejs在解析时出现闪烁的原因及防止闪烁的方法
Sep 19 #Javascript
javascript 判断页面访问方式电脑或者移动端
Sep 19 #Javascript
You might like
pw的一个放后门的方法分析
2007/10/08 PHP
php 生成饼图 三维饼图
2009/09/28 PHP
深入浅出讲解:php的socket通信原理
2016/12/03 PHP
Alliance vs Liquid BO3 第二场2.13
2021/03/10 DOTA
Javascript动态绑定事件的简单实现代码
2010/12/25 Javascript
JavaScript静态类型检查工具FLOW简介
2015/01/06 Javascript
使用jquery制作弹出框效果
2015/04/03 Javascript
Angularjs制作简单的路由功能demo
2015/04/14 Javascript
基于javascript实现样式清新图片轮播特效
2016/03/30 Javascript
详解基于Node.js的微信JS-SDK后端接口实现代码
2017/07/15 Javascript
Vue2 监听属性改变watch的实例代码
2018/08/27 Javascript
axios取消请求的实践记录分享
2018/09/26 Javascript
Vue  webpack 项目自动打包压缩成zip文件的方法
2019/07/24 Javascript
vue使用map代替Aarry数组循环遍历的方法
2020/04/30 Javascript
Vertx基于EventBus发送接受自定义对象
2020/11/16 Javascript
讲解Python中if语句的嵌套用法
2015/05/14 Python
Python通过matplotlib绘制动画简单实例
2017/12/13 Python
Python图像处理之图像的缩放、旋转与翻转实现方法示例
2019/01/04 Python
Python pandas DataFrame操作的实现代码
2019/06/21 Python
python在OpenCV里实现投影变换效果
2019/08/30 Python
Python 找出英文单词列表(list)中最长单词链
2020/12/14 Python
h5封装下拉刷新
2020/08/25 HTML / CSS
中国跨境电商:Tomtop
2017/03/16 全球购物
Kathmandu新西兰官网:新西兰户外运动品牌
2019/07/27 全球购物
大专生自我鉴定范文
2013/10/01 职场文书
实习自我评价怎么写
2013/12/02 职场文书
岗位竞聘演讲稿
2014/01/10 职场文书
晚会主持词开场白
2014/03/17 职场文书
理发店策划方案
2014/06/05 职场文书
反四风个人对照检查材料
2014/09/26 职场文书
承兑汇票转让证明怎么写?
2014/11/30 职场文书
社会治安综合治理责任书
2015/01/29 职场文书
在校证明模板
2015/06/17 职场文书
校园歌手大赛主持词
2015/07/03 职场文书
假如给我三天光明:舟逆水而行,人遇挫而达 
2019/10/29 职场文书
nginx 多个location转发任意请求或访问静态资源文件的实现
2021/03/31 Servers