javascript实现多张图片左右无缝滚动效果


Posted in Javascript onMarch 22, 2017

结构:box包含ul,ul包含4个li;ul绝对定位。

复制li-1、li-2到第li-4后面,为了区分于li-1、li-2,内容改为li-5、li-6,颜色不变。此时ul包含6个li。

需要注意的是,移动的是ul这个大盒子而不是li。

原理:当ul 绝对定位的left 值等于(li-1+li-2+li-3+li-4)的宽度时,利用JavaScript快速复原left 值为0 。

此时请注意盒子里面数字和颜色的变化!

效果图:

javascript实现多张图片左右无缝滚动效果

示例代码:

<!DOCTYPE html>
<html lang="en">
<head>
 <meta charset="UTF-8">
 <meta name="viewport" content="width=device-width, initial-scale=1.0">
 <meta http-equiv="X-UA-Compatible" content="ie=edge">
 <title>Document</title>
 <style media="screen">
  *{
   padding: 0;
   margin: 0;
  }
  ul,li {
   list-style: none;
  }
  img {
   vertical-align: top;
  }
  #box{
   width: 400px;
   height: 100px;
   margin: 100px auto;
   background-color: pink;
   position: relative;
   overflow: hidden;
  }
  #box ul {
   width: 2000px;
   position: absolute;
   left: 0;
   top: 0;
  }
  #box li {
   float: left;
  }
  .aa {
   width: 200px;
   height: 100px;
  }
  .li-1{
   background-color: #f6e659;
  }
  .li-2{
   background-color: #57fa4f;
  }
  .li-3{
   background-color: #3a8ef1;
  }
  .li-4{
   background-color: #c057f1;
  }
 </style>
</head>
<body>
 <div id="box">
  <ul>
   <li class="li-1 aa">li-1</li>
   <li class="li-2 aa">li-2</li>
   <li class="li-3 aa">li-3</li>
   <li class="li-4 aa">li-4</li>
   <li class="li-1 aa">li-5</li>
   <li class="li-2 aa">li-6</li>
  </ul>
 </div>
</body>
</html>
<script type="text/javascript">
 var box = document.getElementById("box");
 var ul = box.children[0];
 var num = 0;
 timer = setInterval(fn,10);
 function fn() {
  num--;
  num <= -800 ? num = 0 : num;
  ul.style.left = num + "px";
 }
</script>

以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,同时也希望多多支持三水点靠木!

Javascript 相关文章推荐
jQuery中文入门指南,翻译加实例,jQuery的起点教程
Feb 09 Javascript
JS面向对象编程之对象使用分析
Aug 19 Javascript
简介alert()与console.log()的不同
Aug 26 Javascript
基于jQuery实现左右图片轮播(原理通用)
Dec 24 Javascript
jquery实现上传文件大小类型的验证例子(推荐)
Jun 25 Javascript
第一次接触神奇的Bootstrap
Oct 14 Javascript
Angular-Touch库用法示例
Dec 22 Javascript
Bootstrap 模态对话框只加载一次 remote 数据的完美解决办法
Jul 09 Javascript
vue富文本编辑器组件vue-quill-edit使用教程
Sep 21 Javascript
jQuery事件多次绑定与解绑问题实例分析
Feb 19 jQuery
解决vue初始化项目时,一直卡在Project description上的问题
Oct 31 Javascript
js实现简单进度条效果
Mar 25 Javascript
tab栏切换原理
Mar 22 #Javascript
js中的DOM模拟购物车功能
Mar 22 #Javascript
js+canvas实现动态吃豆人效果
Mar 22 #Javascript
JavaScript实现星星等级评价功能
Mar 22 #Javascript
discuz表情的JS提取方法分析
Mar 22 #Javascript
详解vue2.0组件通信各种情况总结与实例分析
Mar 22 #Javascript
JS简单封装的图片无缝滚动效果示例【测试可用】
Mar 22 #Javascript
You might like
重料打造自己的“宝马”---第三代
2021/03/02 无线电
PHP 如何利用phpexcel导入数据库
2013/08/24 PHP
php实现比较两个文件夹异同的方法
2015/06/18 PHP
php5.3/5.4/5.5/5.6/7常见新增特性汇总整理
2020/02/27 PHP
location.href 在IE6中不跳转的解决方法与推荐使用代码
2010/07/08 Javascript
JavaScript常用全局属性与方法记录积累
2013/07/03 Javascript
js实现jquery的offset()方法实例
2015/01/10 Javascript
Javascript基础教程之定义和调用函数
2015/01/18 Javascript
JavaScript转换二进制编码为ASCII码的方法
2015/04/16 Javascript
详解ES6之用let声明变量以及let loop机制
2017/07/15 Javascript
Angular实现类似博客评论的递归显示及获取回复评论的数据
2017/11/06 Javascript
js 公式编辑器 - 自定义匹配规则 - 带提示下拉框 - 动态获取光标像素坐标
2018/01/04 Javascript
javascript用rem来做响应式开发
2018/01/13 Javascript
JS扩展String.prototype.format字符串拼接的功能
2018/03/09 Javascript
Vue2.0 $set()的正确使用详解
2020/07/28 Javascript
js实现微信聊天界面
2020/08/09 Javascript
python中PIL安装简单教程
2016/04/21 Python
浅谈Python爬取网页的编码处理
2016/11/04 Python
K-近邻算法的python实现代码分享
2017/12/09 Python
Python3单行定义多个变量或赋值方法
2018/07/12 Python
python pygame模块编写飞机大战
2018/11/20 Python
python 用for循环实现1~n求和的实例
2019/02/01 Python
对django 2.x版本中models.ForeignKey()外键说明介绍
2020/03/30 Python
通过python调用adb命令对App进行性能测试方式
2020/04/23 Python
opencv 查找连通区域 最大面积实例
2020/06/04 Python
Python 串口通信的实现
2020/09/29 Python
纯CSS实现右侧底部悬浮效果(悬浮QQ、微信、微博、邮箱等联系方式)
2015/04/24 HTML / CSS
彪马美国官网:PUMA美国
2017/03/09 全球购物
水上运动奥特莱斯:Wasterports Outlet
2018/08/08 全球购物
文明村镇申报材料
2014/05/06 职场文书
2014年宣传工作总结
2014/11/18 职场文书
教师继续教育反思周记
2015/06/25 职场文书
Pytorch中的数据集划分&正则化方法
2021/05/27 Python
一文搞懂redux在react中的初步用法
2021/06/09 Javascript
mysql定时自动备份数据库的方法步骤
2021/07/07 MySQL
Nginx如何获取自定义请求header头和URL参数详解
2022/07/23 Servers