轮播图是新手学前端的必经之路!
直接上代码!

<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title></title>
<style>
*{
margin: 0;
padding: 0;
}
.all{
margin: 100px auto;
width: 520px;
height: 280px;
position: relative;
cursor: pointer;
overflow: hidden;
}
/*图片*/
.all .pic{
width: 3120px;
height: 280px;
position: absolute;
top: 0;
left: 0;
}
/*左右点击*/
.all .slip{
width: 520px;
height: 24px;
position: absolute;
top: 50%;
left: 0;
margin-top: -12px;
font-size: 36px;
}
.all .slip .left{
float: left;
width: 21px;
height: 36px;
padding-left: 3px;
background: rgba(0, 0, 0, 0.5);
}
.all .slip .right{
float: right;
width: 21px;
height: 36px;
padding-left: 3px;
background: rgba(0, 0, 0, 0.5);
}
.all .slip span{
color: white;
/*width: 10px;*/
line-height: 36px;
display: inline-block;
margin: 0 auto;
}
/*小圆点*/
.all .circle ul{
width: 65px;
height: 13px;
overflow: hidden;
position: absolute;
bottom: 10px;
left: 50%;
margin-left: -32px;
list-style: none;
background: rgba(255, 255, 255, 0.3);
border-radius: 7px;
cursor: hand;
}
.all .circle ul li{
width: 9px;
height: 9px;
background-color: gainsboro;
border-radius: 50%;
float: left;
margin: 2px;
}
</style>
</head>
<body>
<div class="all">
<div class="pic" id="pic">
    <!--这里是要放五张图片不过要把第一张连接到最后一张 这样能显示较好的轮播效果-->       <img src="data:images/1.jpg" alt=""/><img src="data:images/2.jpg" alt=""/><img src="data:images/3.jpg" alt=""/><img src="data:images/4.jpg" alt=""/><img src="data:images/5.jpg" alt=""/><img src="data:images/1.jpg" alt=""/>
    </div>
<div class="slip">
<div class="left" id="slip_left"><span><</span></div>
<div class="right" id="slip_right"><span>></span></div>
</div>
<div class="circle">
<ul id="circle_ul">
<li></li>
<li></li>
<li></li>
<li></li>
<li></li>
</ul>
</div>
</div>
<script>
//获取dom元素
var pic = document.getElementById("pic");
var slipLeft = document.getElementById("slip_left");
var slipRight = document.getElementById("slip_right");
var circileUl = document.getElementById("circle_ul");
var lis = circileUl.getElementsByTagName("li");
//命名变量 leader为盒子所在位置 target为盒子目标位置(在点击左右按钮及小圆点确定位置时用到)
var leader = 0, target = 0;
var time1 = null,time2 = null,time3 = null; //time1 定时器是在没有任何操作下 让图片开始轮着播放出来
time1 = setInterval(autoplay,1);
// 轮播函数
function autoplay() {
leader--;
//当位置超过之后重新回到第一张
leader < -2599? leader = 0 : leader;
pic.style.left = leader + "px";
//当整张图片显示出来的时候停留两秒
if(leader%520 == 0){
target = leader;
clearInterval(time1);
//设置定时器在两秒之后重新开启轮播的定时器time1
time2 = setTimeout(function () {
time1 = setInterval(autoplay,1);
},2000);
}
//将小圆点的颜色全部变为灰色
for(var i = 0; i < lis.length; i++){
lis[i].style.backgroundColor = "gainsboro";
}
//选中当前选中的图片对应的小圆点将他的颜色变为橘黄色
if(-target/520 == 5){
lis[0].style.backgroundColor = "#f40";
}else{
lis[(-target/520)].style.backgroundColor = "#f40";
}
}
//move为在点击之后跳转到目标目标图片的函数
function move(){
leader = leader + (target - leader)/10;
pic.style.left = leader + "px";
if(Math.abs(leader)%520 < 0.1 || (Math.abs(leader)%520 - 520) > -0.1){
leader = target;
clearInterval(time3);
time2 = setTimeout(function () {
time1 = setInterval(autoplay,1);
},2000);
}
for(var i = 0; i < lis.length; i++){
lis[i].style.backgroundColor = "gainsboro";
}
if(-target/520 == 5){
lis[0].style.backgroundColor = "#f40";
}else{
lis[(-target/520)].style.backgroundColor = "#f40";
}
} //左滑点击事件
slipLeft.onclick = function () {
//点击之后先清除定时器
clearInterval(time1);
clearTimeout(time2);
clearTimeout(time3);
//得到目标值
if(leader%520 == 0){
target = target + 520;
}
target > 0? target = -2080 : target;
time3 = setInterval(move,10);
}; //右滑点击事件
slipRight.onclick = function () {
clearInterval(time1);
clearTimeout(time2);
clearTimeout(time3);
if(leader%520 == 0){
target = target - 520;
target < -1560? target = 0 : target;
}else{
target < -1560? target = 0 : target -=520;
}
time3 = setInterval(move,10);
}; //设置点击圆点触发的事件
for(var i = 0; i < lis.length; i++){
//得到下标
lis[i].index = i;
lis[i].onclick = function () {
clearInterval(time1);
clearTimeout(time2);
clearTimeout(time3);
//得到目标位置值
target = - this.index*520;
time3 = setInterval(move,10);
//将选中的的小圆点变色
this.style.backgroundColor = "#f40";
}
}
</script>
</body>
</html>

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

  1. js 原生轮播图插件

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

  2. 小白之js原生轮播图

    html: <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF ...

  3. 原生js焦点轮播图

    原生js焦点轮播图主要注意这几点: 1.前后按钮实现切换,同时注意辅助图2.中间的button随着前后按钮对应切换,同时按button也能跳转到相应的index3.间隔调用与无限轮播.4.注意在动画时 ...

  4. 原生js实现轮播图

    原生js实现轮播图 很多网站上都有轮播图,但找到一个系统讲解的却很难,因此这里做一个简单的介绍,希望大家都能有所收获,如果有哪些不正确的地方,希望大家可以指出. 原理: 将一些图片在一行中平铺,然后计 ...

  5. 封装一个简单的原生js焦点轮播图插件

    轮播图实现的效果为,鼠标移入左右箭头会出现,可以点击切换图片,下面的小圆点会跟随,可以循环播放(为了方便理解,没有补2张图做无缝轮播).本篇文章的主要目的是分享封装插件的思路. 轮播图我一开始是写成非 ...

  6. 原生JS实现轮播图的效果

    原生JS实现轮播图的效果: 只要缕清了全局变量index的作用,这个轮播图也就比较容易实现了:另外,为了实现轮这个效果,有几处clearInterval()必须写上.废话不多说,直接上代码,修复了几个 ...

  7. 使用原生js将轮播图组件化

    代码地址如下:http://www.demodashi.com/demo/11316.html   这是一个轮播图组件,这里是代码地址,需要传入容器的id和图片地址,支持Internet Explor ...

  8. 用原生js封装轮播图

    原生js封装轮播图 对于初学js的同学来说,轮播图还是一个难点,尤其是原生js封装轮播图代码,下面是我之前做的一个轮播图项目中封装好的一些代码,有需要的同学可以看一下,有什么不懂的可以看注释,注释看不 ...

  9. 原生js焦点轮播图的实现

    继续学习打卡,武汉加油,逆战必胜!今日咱们主要探讨一下原生js写轮播图的问题, 简单解析一下思路: 1,首先写好css样式问题 2,考虑全局变量:自动播放的定时器,以及记录图片位置的角标Index 2 ...

随机推荐

  1. JAVA基础--日期处理

    用SimpleDateFormat方法格式化日期格式: package DAO; import java.sql.Connection; import java.sql.DriverManager; ...

  2. Python+Selenium定位不到元素常见原因及解决办法(报:NoSuchElementException)

         在做web应用的自动化测试时,定位元素是必不可少的,这个过程经常会碰到定位不到元素的情况(报selenium.common.exceptions.NoSuchElementException ...

  3. Linux常用的配置文件整理

    /etc/fstab    ( 分区挂载配置文件) /etc/sysconfig/network   (主机名称配置文件) /etc/sysconfig/network-scripts/ifcfg-e ...

  4. OSX下编译安装opencv3.1.0与opencv_contrib_master

    OSX版本10.11.3 1.安装homebrew,打开终端,写入指令 ruby -e "$(curl -fsSL https://raw.githubusercontent.com/Hom ...

  5. 用HTML 格式导出Excel

    只需按照如下格式写就可,在<head> 里面嵌套table,必须修改html的命名空间,加上一些描述.保存为xls文件 <html xmlns:x="urn:schemas ...

  6. lPC1788的串口通讯

    #ifndef __DEBUGSERIAL_H_ #define __DEBUGSERIAL_H_ #include "sys.h" #include "stdio.h& ...

  7. Spring学习---JPA学习笔记

    用了一段时间的Spring,到现在也只是处于会用的状态,对于深入一点的东西都不太了解.所以决定开始深入学习Spring. 本文主要记录JPA学习.在学习JPA之前,需要了解一些ORM的概念. ORM概 ...

  8. struts2拦截器-自定义拦截器,放行某些方法(web.xml配置)

    一.web.xml配置 <filter> <filter-name>encodingFilter</filter-name> <filter-class> ...

  9. Zynq和microblaze的区别

    Zynq钩中PS端的外设之后不需要初始化过程,但是如果在microblaze中连接外设之后需要有初始化过程.

  10. Built-in functions

    转自::http://blog.csdn.net/luyuncheng/article/details/11674123   — Built-in Function: int __builtin_ff ...