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 document.images实例
May 27 Javascript
使用基于jquery的gamequery插件做JS乒乓球游戏
Jul 31 Javascript
javascript中setAttribute()函数使用方法及兼容性
Jul 19 Javascript
Bootstrap3 图片(响应式图片&amp;图片形状)
Jan 04 Javascript
jQuery中Datatables增加跳转到指定页功能
Feb 08 Javascript
React-Router如何进行页面权限管理的方法
Dec 06 Javascript
用node开发并发布一个cli工具的方法步骤
Jan 03 Javascript
vue-router命名视图的使用讲解
Jan 19 Javascript
Echarts实现单条折线可拖拽效果
Dec 19 Javascript
Vue实现兄弟组件间的联动效果
Jan 21 Javascript
vue-quill-editor的使用及个性化定制操作
Aug 04 Javascript
vscode中使用npm安装babel的方法
Aug 02 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
PHP中创建并处理图象
2006/10/09 PHP
php中preg_match的isU代表什么意思
2015/10/01 PHP
Yii视图操作之自定义分页实现方法
2016/07/14 PHP
centos+php+coreseek+sphinx+mysql之一coreseek安装篇
2016/10/25 PHP
PHP+JQUERY操作JSON实例
2017/03/23 PHP
Laravel 5.5 的自定义验证对象/类示例代码详解
2017/08/29 PHP
PHP实现批量重命名某个文件夹下所有文件的方法
2017/09/04 PHP
php记录搜索引擎爬行记录的实现代码
2018/03/02 PHP
tp5实现微信小程序多图片上传到服务器功能
2018/07/16 PHP
php使用event扩展的io复用测试的示例
2020/10/20 PHP
TinyMCE 新增本地图片上传功能
2010/11/05 Javascript
Extjs优化(一)删除冗余代码提高运行速度
2013/04/15 Javascript
Javascript Web Slider 焦点图示例源码
2013/10/10 Javascript
使用javascript实现json数据以csv格式下载
2015/01/09 Javascript
解析JavaScript实现DDoS攻击原理与保护措施
2016/12/26 Javascript
详解关于Vuex的action传入多个参数的问题
2019/02/22 Javascript
[26:21]浴火之凤-TI4世界冠军Newbee战队纪录片
2014/08/07 DOTA
跟老齐学Python之坑爹的字符编码
2014/09/28 Python
Pycharm技巧之代码跳转该如何回退
2017/07/16 Python
Python获取当前函数名称方法实例分享
2018/01/18 Python
Windows下python3.6.4安装教程
2018/07/31 Python
Python3 使用cookiejar管理cookie的方法
2018/12/28 Python
python 求一个列表中所有元素的乘积实例
2019/06/11 Python
Python数据结构与算法(几种排序)小结
2019/06/22 Python
pytorch 实现打印模型的参数值
2019/12/30 Python
西班牙鞋子和箱包在线销售网站:zapatos.es
2020/02/17 全球购物
laravel使用redis队列实例讲解
2021/03/23 PHP
跳槽求职信范文
2014/05/26 职场文书
平安工地汇报材料
2014/08/19 职场文书
党政领导班子群众路线对照检查材料
2014/10/26 职场文书
2015年国庆节慰问信
2015/03/23 职场文书
本科毕业论文致谢怎么写
2015/05/14 职场文书
运动会宣传稿100字
2015/07/23 职场文书
工作建议书范文
2019/07/08 职场文书
opencv检测动态物体的实现
2021/07/21 Python
Python实现批量将文件复制到新的目录中再修改名称
2022/04/12 Python