原生JS实现旋转木马轮播图特效
大概是这个样子:

首先来简单布局一下(emm...随便弄一下吧,反正主要是用js来整的)
<!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>旋转木马轮播图</title>
<script src="js/index.js"></script>
<style>
* {
margin: 0;
padding: 0;
}
ul, li {
list-style: none;
}
.wrap {
margin: 0 auto;
width: 1050px;
}
.slider {
position: relative;
margin: 50px auto;
height: 400px;
}
.slider li {
position: absolute;
}
.slider li img {
width: 100%;
}
.slider .arrow-l,
.slider .arrow-r{
position: absolute;
top: 0;
display: none;
width: 80px;
height: 400px;
background-size: 80px;
cursor: pointer;
opacity: 0.8;
z-index: 99;
}
.arrow-r {
right: 80px;
background: url(img/next.png) no-repeat 0;
}
.arrow-l {
left: 80px;
background: url(img/prev.png) no-repeat 0;
}
</style>
</head>
<body>
<div class="wrap">
<div class="slider">
<ul>
<li><img src="img/img1.jpg" alt=""></li>
<li><img src="img/img2.jpg" alt=""></li>
<li><img src="img/img3.jpg" alt=""></li>
<li><img src="img/img4.jpg" alt=""></li>
<li><img src="img/img5.jpg" alt=""></li>
</ul>
<div class="arrows">
<i class="arrow arrow-l"></i>
<i class="arrow arrow-r"></i>
</div>
</div>
</div>
</body>
</html>
下边来进入主要部分
其实主要就是动画函数的封装以及对数组的改变
动画函数部分的注释,博主的上一篇博客有写:原生JS实现动画函数的封装。这里就不重复啦~
将图片相关样式(大小、定位、透明度等)存放到arr数组里。
当用户点击左右箭头时,让数组进行相应变化(如果点击右箭头,就删除数组最后那个元素,把它添加到最前边;如果点击左箭头,就删除数组最前边那个元素,把它添加到最后边),改变完数组再调用一下move()函数(让图片轮播)
详细代码如下
window.addEventListener("load", function() {
var arr = [
{ //
width: 450,
top: 60,
left: 0,
opacity: 40,
zIndex: 2
},
{ //
width: 550,
top: 30,
left: 100,
opacity: 70,
zIndex: 3
},
{ // 3 中间图片
width: 650,
top: 0,
left: 200,
opacity: 100,
zIndex: 4
},
{ //
width: 550,
top: 30,
left: 400,
opacity: 70,
zIndex: 3
},
{ //
width: 450,
top: 60,
left: 600,
opacity: 40,
zIndex: 2
}
];
var slider = document.querySelector(".slider");
var lis = slider.querySelectorAll("li");
var arrow_l = slider.querySelector(".arrow-l");
var arrow_r = slider.querySelector(".arrow-r");
// 鼠标移入移出箭头显示隐藏
slider.addEventListener("mouseover", function() {
arrow_l.style.display = 'block';
arrow_r.style.display = 'block';
});
slider.addEventListener("mouseout", function() {
arrow_l.style.display = 'none';
arrow_r.style.display = 'none';
});
var flag = true; // flag节流阀 为了解决点击过快而产生bug
move(); // 先调用一下,为了刚打开浏览器时渲染页面
// 点击左右箭头轮播图片
arrow_r.addEventListener("click", function() {
if(flag) {
flag = false; // 关闭节流阀 等到动画结束了才能继续执行点击操作
arr.unshift(arr.pop()); // 将数组最后边的元素删除,添加到最前边
move(); // 轮播图片
}
});
arrow_l.addEventListener("click", function() {
if(flag) {
flag = false;
arr.push(arr.shift()); // 将数组最前边的元素删除,添加到最后边
move();
}
});
// 让每个图片执行动画
function move() {
for(var i = 0; i < lis.length; i++) {
animate(lis[i], arr[i], function() {
flag = true; // 回调函数,当动画执行完 再把节流阀打开
});
}
}
// 动画函数
function animate(obj, json, callback) {
clearInterval(obj.timer);
obj.timer = setInterval(function() {
var bool = true;
for(var attr in json) {
var icur = 0;
if(attr == 'opacity') {
icur = Math.round(parseFloat(getStyle(obj, attr)) * 100);
} else {
icur = parseInt(getStyle(obj, attr));
}
var speed = (json[attr] - icur) / 10;
speed = speed > 0 ? Math.ceil(speed) : Math.floor(speed);
if(icur != json[attr]) {
bool = false;
}
if(attr == 'opacity') {
obj.style.filter = 'alpha(opacity = '+ (icur + speed) +')';
obj.style.opacity = (icur + speed) / 100;
} else if(attr == 'zIndex') {
obj.style.zIndex = json[attr];
} else {
obj.style[attr] = icur + speed + 'px';
}
}
if(bool) {
clearInterval(obj.timer);
callback && callback();
}
},15);
}
// 获取属性函数
function getStyle(obj, attr) {
if(obj.currentStyle){ //IE浏览器
return obj.currentStyle[attr];
}else{ //chrome、firefox等浏览器
return getComputedStyle(obj,null)[attr];
}
}
});
原生JS实现旋转木马轮播图特效的更多相关文章
- jQuery与原生js实现banner轮播图
jQuery与原生js实现banner轮播图: (jq需自己加载)(图片需自己加载) <!DOCTYPE html> <html> <head> <meta ...
- 原生JS实现简易轮播图
原生JS实现简易轮播图(渐变?) 最近做网页总是会用到轮播图,我就把之前写的轮播图单独拿出来吧,如果有...如果真的有人也需要也可以复制去用用啊..哈~.. window.onload = funct ...
- 自己用原生JS写的轮播图,支持移动端触屏滑动,面向对象思路。分页器圆点支持click和mouseover。
自己用原生javascript写的轮播图,面向对象思路,支持移动端手指触屏滑动.分页器圆点可以选择click点击或mouseover鼠标移入时触发.图片滚动用的setInterval,感觉setInt ...
- 自己用原生JS写的轮播图,支持移动端触摸滑动,分页器圆点可以支持mouseover鼠标移入和click点击,高手看了勿喷哈
自己用原生JavaScript写的轮播图,分页器圆点按钮可支持click点击,也可支持mouseover鼠标悬浮触发,同时支持移动端触摸滑动,有兴趣的友友可以试试哈,菜鸟一枚,高手看了勿喷,请多多指正 ...
- 原生 js 左右切换轮播图
使用方法: 可能很多人对轮播图感兴趣,下面奉上本人的 原生 js 轮播代码复制 js 到页面的最底部,样式在 css 里改,js 基本不用动,有什么不懂的可以 加本人 QQ172360937 咨询 或 ...
- photoSlider-html5原生js移动开发轮播图-相册滑动插件
简单的移动端图片滑动切换浏览插件 分别引用css文件和js文件 如: <link rel="stylesheet" type="text/css" hre ...
- 原生js写简单轮播图方式1-从左向右滑动
轮播图就是让图片每隔几秒自动滑动,达到图片轮流播放的效果.轮播图从效果来说有滑动式的也有渐入式的,滑动式的轮播图就是图片从左向右滑入的效果,渐入式的轮播图就是图片根据透明度渐渐显示的效果,这里说的是实 ...
- 【原生JS】层叠轮播图
又是轮播?没错,换个样式玩轮播. HTML: <!DOCTYPE html> <html lang="en"> <head> <meta ...
- 原生js实现的轮播图,易用+可多用
<!doctype html> <html> <head> <meta charset="utf-8"> <title> ...
随机推荐
- jdbc url的若干参数
参数名称 参数说明 缺省值 最低版本要求 user 数据库用户名,用于连接数据库 无 所有版本 password 用户密码(用于连接数据库) 无 所有版本 useUnicode 是否使用Unicode ...
- HTML表格显示的笔记
有时需要显示的复杂表头 如图所示 <table id="" cellpadding="0" cellspacing="0" bord ...
- javascript当中prototype用法
prototype见上一节,马克-to-win:prototype作用就是给某个类增加一个实例方法. 例 3.6.2 <head> <meta http-equiv=" ...
- Windows启动项更改
笔者遇到的问题: 之前新装了Windows10系统,但没注意到的是竟然是deepin和Windows10双系统,一是用不到deepin系统,二是占用C盘空间太多,就重新装回了Windows7系统,但重 ...
- Tomcat解压版-环境配置
[问题]Tomcat解压版在本地后,双击双击startup.bat,闪退 [解决办法] 1.在已解压的tomcat的bin文件夹下找到startup.bat,右击->编辑.在文件头加入下面 ...
- 操作系統3-內存管理(Linux內存管理)
操作系統3-內存管理(Linux系統的內存管理方法) 9.Linux系統的內存管理方法 Linux採用"按需調頁"算法,支持三層管理策略.由於Intel CPU在硬件級提供了段式存 ...
- 前后端交互技术之servlet与form表单提交请求及ajax提交请求
1.先来个简单的form表单 login.jsp,建在webcontent目录下(url写相对路径就可以了) <!DOCTYPE html><html><head> ...
- java基础之 变量
变量是一个内存位置的名称. 1.成员变量(实例变量,属性) 成员变量就是类中的属性,当创建对象的时候,每个对象都有一份属性.一个对象中的属性就是成员变量. 2.本地变量(局部变量) 在方法内声明的变量 ...
- spring(四):DI流程
在IoC容器初始化过程中,一般不包含Bean依赖注入的实现. 依赖注入一般发生在应用第一次向容器获取Bean时(getBean),但是有一个例外. 在使用IoC容器时有一个预实例化的配置,即通过laz ...
- C++-LUOGU2938- [USACO09FEB]股票市场Stock Market-[完全背包]
开O2,开O2,开O2 重要的事情说三遍 #include <set> #include <map> #include <cmath> #include <q ...