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操作页面表格,元素的一些技巧
Feb 02 Javascript
JavaScript-世界上误解最深的语言分析
Aug 12 Javascript
JQuery获取元素文档大小、偏移和位置和滚动条位置的方法集合
Jan 12 Javascript
JQuery中的ready函数冲突的解决方法
May 17 Javascript
javascript实例--教你实现扑克牌洗牌功能
May 15 Javascript
jquery实现适用于门户站的导航下拉菜单效果代码
Aug 24 Javascript
JS原生数据双向绑定实现代码
Aug 14 Javascript
JavaScript学习笔记之惰性函数示例详解
Aug 27 Javascript
浅谈vue项目优化之页面的按需加载(vue+webpack)
Dec 11 Javascript
基于vue.js实现的分页
Mar 13 Javascript
js实现二级菜单点击显示当前内容效果
Apr 28 Javascript
vue在自定义组件中使用v-model进行数据绑定的方法
Mar 25 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
TMDPHP 模板引擎使用教程
2012/03/13 PHP
php清除和销毁session的方法分析
2015/03/19 PHP
CI映射(加载)数据到view层的方法
2016/03/28 PHP
PHP实现的超长文本分页显示功能示例
2018/06/04 PHP
火狐textarea输入法的bug的触发及解决
2013/07/24 Javascript
Event altKey,ctrlKey,shiftKey属性解析
2013/12/18 Javascript
js获取和设置属性的方法
2014/02/20 Javascript
基于javascript的JSON格式页面展示美化方法
2014/07/02 Javascript
浏览器中url存储的JavaScript实现
2015/07/07 Javascript
javascript与Python快速排序实例对比
2015/08/10 Javascript
jQuery表格的维护和删除操作
2017/02/03 Javascript
Three.js利用性能插件stats实现性能监听的方法
2017/09/25 Javascript
Mac下通过brew安装指定版本的nodejs教程
2018/05/17 NodeJs
详解vue路由篇(动态路由、路由嵌套)
2019/01/27 Javascript
js前端面试之同步与异步问题详解
2019/04/03 Javascript
浅谈Vue.set实际上是什么
2019/10/17 Javascript
解决vue项目打包上服务器显示404错误,本地没出错的问题
2020/11/03 Javascript
Python with的用法
2014/08/22 Python
Python抓取京东图书评论数据
2014/08/31 Python
在Python中处理字符串之isdigit()方法的使用
2015/05/18 Python
Python通过poll实现异步IO的方法
2015/06/04 Python
Python将多个excel文件合并为一个文件
2018/01/03 Python
详解Numpy中的数组拼接、合并操作(concatenate, append, stack, hstack, vstack, r_, c_等)
2019/05/27 Python
对PyQt5的输入对话框使用(QInputDialog)详解
2019/06/25 Python
python画微信表情符的实例代码
2019/10/09 Python
如何基于Python制作有道翻译小工具
2019/12/16 Python
美国高街时尚品牌:OASAP
2016/07/24 全球购物
英国领先的办公用品供应商:Viking
2016/08/01 全球购物
大学生职业生涯规划书模板
2014/01/18 职场文书
中专自我鉴定
2014/02/05 职场文书
小学生保护环境倡议书
2014/05/15 职场文书
司法工作人员群众路线对照检查材料思想汇报
2014/09/30 职场文书
工人先锋号事迹材料
2014/12/24 职场文书
团队执行力培训心得体会
2015/08/15 职场文书
MySQL数据库压缩版本安装与配置详细教程
2021/05/21 MySQL
Pygame Event事件模块的详细示例
2021/11/17 Python