<!DOCTYPE html>
  <html>
  <head>
  <meta charset="UTF-8">
  <title></title>
  <style>
  *{
  margin: 0;
  padding: 0;
  text-decoration: none;
  }
  #container{
  width: 600px;
  height: 400px;
  border: 3px solid gold;
  position: relative;
  margin: 300px auto;
  overflow: hidden;
  z-index: 2;
  /*transition: all 0.5s ease;*/
  }
  #list{
  width: 3600px;
  height: 400px;
  position: absolute;
  z-index: 1;
  left: -600px;
  }
  #list img{
  width: 600px;
  height: 400px;
  float: left;
  }
  span{
  position: absolute;
  display: block;
  width: 10px;
  height: 10px;
  border-radius: 50%;
  z-index: 2;
  background: gainsboro;
  bottom: 10px;
  }
  p{
  z-index: 2;
  width: 50px;
  line-height: 50px;
  background: rgba(0,0,0,0.3);
  color: white;
  position: absolute;
  font-size: 40px;
  text-align: center;
  }
  .p1{
  top: 175px;
  left: 0;
  }
  .p2{
  top: 175px;
  right: 0px;
  }
  #container:hover .p1,#container:hover .p2{
  background: rgba(0,0,0,0.7);
  }
   
  </style>
  </head>
  <body>
  <div id="container">
  <div id="list">
  <img src="img/4.jpg" alt="" />
  <img src="img/1.jpg" alt="" />
  <img src="img/2.jpg" alt="" />
  <img src="img/3.jpg" alt="" />
  <img src="img/4.jpg" alt="" />
  <img src="img/1.jpg" alt="" />
  </div>
  <p class="p1" onclick="lfClick(10)">&lt;</p>
  <p class="p2" onclick="lfClick(-10)">&gt;</p>
  <span onclick="oClick(-600,0)"></span>
  <span onclick="oClick(-1200,1)"></span>
  <span onclick="oClick(-1800,2)"></span>
  <span onclick="oClick(-2400,3)"></span>
  </div>
  </body>
  <script type="text/javascript">
  var list = document.getElementById('list');
  var ps = document.querySelectorAll('p');
  var timer = null ;
  var spans = document.querySelectorAll('span');
  var timeOut = null;
  for(var i = 0 ;i<spans.length; i++){
  spans[i].style.left = 250 + i*20 + 'px';
  }
   
  timer=setInterval(doMove,20);
  function doMove(){
  var speed = parseInt(getStyle()) - 10;
  list.style.left = speed +'px';
   
  if(speed %600 ==0){
  clearInterval(timer);
  timeOut = setTimeout(function(){
  timer=setInterval(doMove,20);
  },1000);
  }
  btnColor(speed);
   
  }
   
   
  //前后事件
  var setInter =null;
  // ps[0].onclick = lfClick(10);
  function lfClick(dir) {
  clearInterval(timer);
  clearInterval(setInter);
   
  if(parseInt(getStyle()) < -600 && parseInt(getStyle())>-1200){
  list.style.left = -600 +'px';
   
  }
   
  if(parseInt(getStyle()) < -1200 && parseInt(getStyle())>-1800){
  list.style.left = -1200 +'px';
  }
  if(parseInt(getStyle()) < -1800 && parseInt(getStyle())>-2400){
  list.style.left = -1800 +'px';
  }
  if(parseInt(getStyle()) < -2400 && parseInt(getStyle())>-3000){
  list.style.left = -2400 +'px';
  }
   
  setInter = setInterval(function(){
  clearInterval(timer);
  clearTimeout(timeOut);
  var speed = parseInt(getStyle()) + dir ;
  list.style.left = speed + 'px';
  btnColor(speed);
  if(speed %600 == 0){
  clearInterval(setInter);
  timeOut = setTimeout(function(){
  timer=setInterval(doMove,20);
  },1000);
  if(speed == 0){
  list.style.left = '-2400px';
  }
  if(speed == -3000){
  list.style.left = '-600px';
  }
  }
   
   
   
  },10)
   
  }
   
  function getStyle(){
  return list.currentStyle? list.currentStyle.left:getComputedStyle(list).left;
  }
   
  function oClick(dir,index){
  clearInterval(timer);
  clearTimeout(timeOut)
  list.style.left = dir + 'px';
  for(var i = 0 ;i<spans.length; i++){
  spans[i].style.background='gainsboro';
  }
  spans[index].style.background = 'red';
  timeOut = setTimeout(function(){
  timer=setInterval(doMove,20);
  },1000);
  }
   
  function btnColor(speed){
  if(speed == -600 ){
  spans[0].style.background = 'red';
  spans[3].style.background = 'gainsboro';
  spans[1].style.background = 'gainsboro';
   
  }
  if(speed == -1200 ){
  spans[1].style.background = 'red';
  spans[0].style.background = 'gainsboro';
  spans[2].style.background = 'gainsboro';
  }
  if(speed == -1800){
  spans[2].style.background = 'red';
  spans[1].style.background = 'gainsboro';
  spans[3].style.background = 'gainsboro';
  }
  if(speed == -2400 ||speed ==0){
  spans[3].style.background = 'red';
  spans[2].style.background = 'gainsboro';
  spans[0].style.background = 'gainsboro';
  }
   
  if(speed == -3000){
  list.style.left = -600 +'px';
  spans[0].style.background = 'red';
  spans[3].style.background = 'gainsboro';
  }
  }
   
  </script>
  </html>

js原生的轮播图的更多相关文章

  1. js原生实现轮播图效果(面向对象编程)

    面向对象编程js原生实现轮播图效果 1.先看效果图 2.需要实现的功能: 自动轮播 点击左右箭头按钮无缝轮播 点击数字按钮切换图片 分析:如何实现无缝轮播? 在一个固定大小的相框里有一个ul标签,其长 ...

  2. JS+css3焦点轮播图PC端

    <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...

  3. jQuery与原生js实现banner轮播图

    jQuery与原生js实现banner轮播图: (jq需自己加载)(图片需自己加载) <!DOCTYPE html> <html> <head> <meta ...

  4. 原生JS实现简易轮播图

    原生JS实现简易轮播图(渐变?) 最近做网页总是会用到轮播图,我就把之前写的轮播图单独拿出来吧,如果有...如果真的有人也需要也可以复制去用用啊..哈~.. window.onload = funct ...

  5. 原生 js 左右切换轮播图

    使用方法: 可能很多人对轮播图感兴趣,下面奉上本人的 原生 js 轮播代码复制 js 到页面的最底部,样式在 css 里改,js 基本不用动,有什么不懂的可以 加本人 QQ172360937 咨询 或 ...

  6. 自己用原生JS写的轮播图,支持移动端触屏滑动,面向对象思路。分页器圆点支持click和mouseover。

    自己用原生javascript写的轮播图,面向对象思路,支持移动端手指触屏滑动.分页器圆点可以选择click点击或mouseover鼠标移入时触发.图片滚动用的setInterval,感觉setInt ...

  7. 原生JS实现旋转木马轮播图特效

    大概是这个样子: 首先来简单布局一下(emm...随便弄一下吧,反正主要是用js来整的) <!DOCTYPE html> <html lang="en"> ...

  8. photoSlider-html5原生js移动开发轮播图-相册滑动插件

    简单的移动端图片滑动切换浏览插件 分别引用css文件和js文件 如: <link rel="stylesheet" type="text/css" hre ...

  9. 自己用原生JS写的轮播图,支持移动端触摸滑动,分页器圆点可以支持mouseover鼠标移入和click点击,高手看了勿喷哈

    自己用原生JavaScript写的轮播图,分页器圆点按钮可支持click点击,也可支持mouseover鼠标悬浮触发,同时支持移动端触摸滑动,有兴趣的友友可以试试哈,菜鸟一枚,高手看了勿喷,请多多指正 ...

随机推荐

  1. 【安装eclipse, 配置java环境教程】 编写第一个java程序

    写java通常用eclipse编写,还有一款编辑器比较流行叫IJ.这里我们只说下eclipse编写java的前期工作. 在安装eclipse之前要下载java的sdk文件,即java SE:否则无法运 ...

  2. SQL基础笔记

    Codecademy中Learn SQL, SQL: Table Transformaton和SQL: Analyzing Business Metrics三门课程的笔记,以及补充的附加笔记. Cod ...

  3. git的安装和环境配置过程(学习笔记)

    1.安装git 官网下载:https://github.com(目前官网好像找不到了,但是妙味的视频里面是在官网下载的)https://git-for-windows.github.io/ (廖雪峰老 ...

  4. SaberRD之交流分析

    交流分析(AC Analysis)也叫做小信号(Small-Signal)分析,也即分析电路的小信号频率响应,更严谨的定义是:分析工作在直流偏置电压下的非线性电路对于一定频率范围内的输入小信号的系统响 ...

  5. MVC和三层架构

    从最开始写程序到现在,一路上听到架构这个词已经无数次了,在工作和圈子里也不停听到大家在讨论它,但是很多时候发现不少人对这个概念的理解都是很模糊的,无意间在知道上看到一个朋友的回答,感觉很不错,特转帖到 ...

  6. 学习笔记——Java包装类

    由于Java不能定义基本类型的对象,所以通过包装类提供了各种可用方法的封装. 这一部分的知识,需要能够通过查看Integer.Boolean.Byte.Character.Double.Number类 ...

  7. CSS下拉菜单

    <!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01//EN" "http://www.w3.org/TR/html4/stri ...

  8. Centos7 安装 zabbix3.2

    简介: Zabbix的一个很优秀的分布式监控服务器, 它有两部分组成: 1. “zabbix-server”用来收集并且在web端展示数据 2. “zabbix-agent”用来采集数据,发送给ser ...

  9. Android学习总结(一)——Activity的基本概念与Activity的生命周期

    一.Activity的基本概念 Activity是Android的四大组件之一,它是一种可以包含用户界面的组件,主要用于和用户进行交互,比如打电话,照相,发送邮件,或者显示一个地图!Activity用 ...

  10. smarty模板基础1

    smarty模板的作用可以让前端和后端分离(也就是前端的显示页面和后端的php代码). smarty模板的核心是一个类,下载好的模板中有这么几个重要的文件夹 (1)libs核心文件夹(2)int.in ...