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 相关文章推荐
JS文本框默认值处理详解
Jul 10 Javascript
JavaScript中的全局对象介绍
Jan 01 Javascript
JS+CSS实现经典的左侧竖向滑动菜单效果
Sep 23 Javascript
javascript数据类型验证方法
Dec 31 Javascript
实用jquery操作表单元素的简单代码
Jul 04 Javascript
vue.js实现表格合并示例代码
Nov 30 Javascript
Javascript this 函数深入详解
Dec 13 Javascript
jQuery+koa2实现简单的Ajax请求的示例
Mar 06 jQuery
前端天气插件tpwidget使用方法详解
Jun 24 Javascript
微信小程序下拉框搜索功能的实现方法
Jul 31 Javascript
vue+elementUI动态生成面包屑导航教程
Nov 04 Javascript
React组件设计模式之组合组件应用实例分析
Apr 29 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
使用 MySQL 开始 PHP 会话
2006/12/21 PHP
动易数据转成dedecms的php程序
2007/04/07 PHP
基于PHP的cURL快速入门教程 (小偷采集程序)
2011/06/02 PHP
php获取bing每日壁纸示例分享
2014/02/25 PHP
PHP实现的汉字拼音转换和公历农历转换类及使用示例
2014/07/01 PHP
PHP中判断文件存在使用is_file还是file_exists?
2015/04/03 PHP
PHP通过get方法获得form表单数据方法总结
2018/09/12 PHP
php数值计算num类简单操作示例
2020/05/15 PHP
jquery+json 通用三级联动下拉列表
2010/04/19 Javascript
javascript获取隐藏dom的宽高 具体实现
2013/07/14 Javascript
JavaScript使用addEventListener添加事件监听用法实例
2015/06/01 Javascript
学习JavaScript事件流和事件处理程序
2016/01/25 Javascript
Js 获取、判断浏览器版本信息的简单方法
2016/08/08 Javascript
javaScript中定义类或对象的五种方式总结
2016/12/04 Javascript
jquery插件treegrid树状表格的使用方法详解(.Net平台)
2017/01/03 Javascript
jQuery插件HighCharts绘制的2D堆柱状图效果示例【附demo源码下载】
2017/03/14 Javascript
react-native组件中NavigatorIOS和ListView结合使用的方法
2017/09/30 Javascript
vue使用keep-alive实现数据缓存不刷新
2017/10/21 Javascript
JS实现的倒计时恢复按钮点击功能【可用于协议阅读倒计时】
2018/04/19 Javascript
Python中顺序表的实现简单代码分享
2018/01/09 Python
使用Python制作微信跳一跳辅助
2018/01/31 Python
django中的HTML控件及参数传递方法
2018/03/20 Python
Python获取系统所有进程PID及进程名称的方法示例
2018/05/24 Python
PyQt5中多线程模块QThread使用方法的实现
2020/01/31 Python
Python3 socket即时通讯脚本实现代码实例(threading多线程)
2020/06/01 Python
如何基于Python代码实现高精度免费OCR工具
2020/06/18 Python
scrapy头部修改的方法详解
2020/12/06 Python
亿阳信通股份有限公司笔试题(C#)
2016/03/04 面试题
出纳担保书范文
2014/04/02 职场文书
大专毕业生求职信
2014/07/05 职场文书
如何写早恋检讨书
2014/09/10 职场文书
2014个人年度工作总结范文
2014/12/24 职场文书
2016年村党支部公开承诺书
2016/03/24 职场文书
公司年会主持词范文!
2019/05/07 职场文书
vue如何使用模拟的json数据查看效果
2022/03/31 Vue.js
悬疑名作《朋友游戏》动画无字ED宣传片 新角色公开
2022/04/13 日漫