原生JS实现匀速图片轮播动画
作者:lijiao 发布时间:2024-06-07 15:28:15
标签:js,图片轮播
JS实现轮播图实现结果图:
需求:
1 根据图片动态添加小圆点
2 目标移动到小圆点轮播图片
3 鼠标离开图片,定时轮播图片;鼠标在图片上时暂停
4 左右两侧可点击轮播图片
一、布局部分
html部分
<div class="w main clearfix"><!--主内容部分开始-->
<div class="slider"><!--轮播图部分开始-->
<ul class="imgs" id="slider_imgs">
<li><img src="images/slider01.jpg" id="slider1" alt=""/>
</li>
<li><img src="images/slider02.jpg" id="slider2" alt=""/>
</li>
<li><img src="images/slider03.jpg" id="slider3" alt=""/>
</li>
<li><img src="images/slider04.jpg" id="slider4" alt=""/>
</li>
<li><img src="images/slider05.jpg" id="slider5" alt=""/>
</li>
<li><img src="images/slider01.jpg" id="slider0" alt=""/>
</li>
</ul>
<div class="arrow" id="arrow">
<a href="javascript:;" class="arrow_1"><</a>
<a href="javascript:;" class="arrow_2">></a>
</div>
</div><!--轮播图部分结束-->
</div>
css部分
.slider ul.imgs{height:453px;width:4380px;position:absolute;}
.slider ul.imgs li{display:block; width:730px;height:453px;float:left;}
.slider .circle{position:absolute;left:50%;bottom:8px;}
.slider .circle li{cursor:pointer;float:left;width:18px;height:18px;margin:4px;background-color:#3e3e3e;border-radius: 50%;text-align: center;color:#fff;}
.slider .circle li.current{background:pink;color:white;}
JS部分
1这是匀速动画函数的封装
/*
***obj:做动画的DOM对象
***target:对象最终运动到的目标位置(X轴)
*/
function animate(obj,target) {
//每次调用要先清定时器
clearInterval(obj.Timer);
//根据目标位置判断移动的方向,每到目标位置步长为20,否则为-20
var speed = target>obj.offsetLeft?20:-20;
obj.Timer =setInterval(function () {
var left = obj.offsetLeft;
obj.style.left = left+speed+"px";
var result = target-left;
//目标位置与当前位置在步长20以内,则到达目标位置
if(Math.abs(result)<=20){
//停止运动
clearInterval(obj.Timer);
//有20像素差距 我们直接跳转目标位置
obj.style.left=target+ "px";
}
},2函数:
`这里写代码片0);
}
轮播图封装函数:
function slider(){
//焦点图信息DOM节点
var imgs=document.getElementById("slider_imgs");
var slides =imgs.parentNode;
var lis =imgs.getElementsByTagName("li");
var arrows = document.getElementById("arrow");
var arrowLink=arrows.children;
//创建小圆点
var circle=document.createElement("ol");
circle.setAttribute("class","circle");
imgs.parentNode.appendChild(circle);
for(var i=0,len=lis.length-1;i<len;i++){
var li =document.createElement("li");
li.innerHTML = i+1;
circle.appendChild(li);
}
//marginLeft=-imgli(length)*olLi(width)/2
circle.style.marginLeft = (-13*len)+"px";
var olLis =circle.children;
olLis[0].className="current";
//为小圆点添加鼠标事件
for(var i=0;i<olLis.length;i++){
//当前小圆点索引
olLis[i].index = i;
olLis[i].onmouseover=function () {
for(var j=0;j<olLis.length;j++) {
olLis[j].className = "";
}
this.className="current";
//图片切换 imgs的CSS部分加上定位
animate(imgs,this.index*(-lis[0].offsetWidth));
//当鼠标挪到定时器,当前播放图片与原点位置回原
k=z=p=q=this.index;
};
}
//鼠标移动到轮播图,不定时播放
slides.onmouseover=function () {
//清除自动轮播定时器
clearInterval(Time);
};
//鼠标移开,自动轮播
slides.onmouseout=function () {
Time =setInterval(autoPlay,1000);
};
//定时器部分
var Time=null,k=0,z=0;
Time=setInterval(autoPlay,1000);
//自动轮播图片,定时器Time
function autoPlay() {
k++;
if(k>lis.length-1){
imgs.style.left=0;
k=1;
}
animate(imgs,k*(-lis[0].offsetWidth));
z++;
if(z>olLis.length-1){
z=0;
}
for(var j=0;j<olLis.length;j++) {
olLis[j].className = "";
}
olLis[z].className="current";
}
var q=0;var p=0;
arrowLink[1].onclick=function () {
q++;
if(q>lis.length-1){
imgs.style.left=0;
q=1;
}
p++;
if(p>olLis.length-1){
p=0;
}
for(var j=0;j<olLis.length;j++) {
olLis[j].className = "";
}
olLis[p].className="current";
animate(imgs,q*(-lis[0].offsetWidth));
}
}
精彩专题分享:jQuery图片轮播 JavaScript图片轮播 Bootstrap图片轮播


猜你喜欢
- 图像文件是自己仿照mnist格式制作,每张图像大小为128*128import structimport matplotlib.pyplot
- 网页给人最直观的感受就是它的页面框架与构造,就像一座大楼的主体框架与形态,你可能记不起东方明珠塔和艾菲尔铁塔是用什么颜色或什么材料涂的外墙,
- 引入在通过scrapy框架进行某些网站数据爬取的时候,往往会碰到页面动态数据加载的情况发生,如果直接使用scrapy对其url发请求,是绝对
- python 2.6编写,自己瞎写的,备用''' Export and Import ElasticSe
- 原文:http://www.smashingmagazine.com/ ... emarkable-favicons/翻译:Blank(怿飞
- PyCharm是Python著名的Python集成开发环境(IDE)conda有Miniconda和Anaconda,前者应该是类似最小化版
- 首先水仙花数是什么?水仙花数(Narcissistic number)也被称为超完全数字不变数(pluperfect digital inv
- 最近打算开始研究一下机器学习,今天在windows上装tensorflow花了点功夫,其实前面的步骤不难,只要依次装好python3.5,n
- 孤立帐户,就是某个数据库的帐户只有用户名而没有登录名,这样的用户在用户库的sysusers系统表中存在,而在master数据库的syslog
- 如下所示:alist=[1,2]] >>>[1,2] alist.append([3,4]) >>>[1
- 本文实例讲述了Python多进程原理与用法。分享给大家供大家参考,具体如下:进程是程序在计算机上的一次执行活动。当你运行一个程序,你就启动了
- python虚拟环境迁移:注意事项:直接将虚拟环境复制到另一台机器,直接执行是会有问题的。那么可以采用以下办法:思路:将机器1虚拟环境下的包
- 引言:在Python3下运行Matplotlib之时,碰到了”No module named _tkinter“的问题,花费数小时进行研究解
- 一、开发时管理数据库遇到的问题:现在开发一般都是团队开发,这样就会出现项目同步的问题,代码同步可以通过SVN工具管理起来,那数据库同步怎么办
- Mysql的安装方法 安装mysql的步骤如下:请注意按图中所示,有些选项和默认是不一样的。同时,如果您是重新安装mysql的话,要注意先备
- 以下内容是针对安装tensorflow-CPU版本的。tensorflow已经支持Python3.8版本的安装。可以查看自己的Python版
- 先看一个实例这是我用asp写的一个搜索一个字符串里面第一张图片地址的函数(当然你可以将values那里换一个得到所有图片地址)functio
- import time, randomclass GuessNum: def __init__(self
- 前言最近更新了Python版本,准备写个爬虫,意外的发现urllib库中属性不存在urlopen,于是各种google,然后总结一下给出解决
- JavaScript 中的 this 指向问题有很多文章在解释,仍然有很多人问。上周我们的开发团队连续两个人遇到相关问题,所以我不得不将关于