原生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> ...
随机推荐
- 页面内容不满屏幕高度时,footer底部显示
底部高度固定的情况下 <style> body,html{ height: 100%; margin: 0; } .content{ min-height: 100%; padding-b ...
- 06 部署redis缓存数据库
1 安装redis $ sudo apt-get install redis-server 安装完成后,Redis服务器会自动启动,检查Redis服务器程序 注:在安装过程中,腾讯服务器会中途停止. ...
- PHP毫秒
PHP毫秒 php的毫秒是没有默认函数的,但提供了一个microtime()函数,该函数返回包含两个元素,一个是秒数,一个是小数表示的毫秒数,借助此函数,可以很容易定义一个返回毫秒数的函数,例如: ...
- NMF: non-negative matrix factorization.
1. 矩阵分解可以用来解决什么方法, 以及how? 利用矩阵分解来解决实际问题的分析方法很多,如PCA(主成分分析).ICA(独立成分分析).SVD(奇异值分解).VQ(矢量量化)等.在所有这些方法中 ...
- C++-static作用(转)
C++中static的作用 C++的static有两种用法:面向过程程序设计中的static和面向对象程序设计中的static.前者应用于普通变量和函数,不涉及类:后者主要说明static在类中的作用 ...
- 利用python装饰器为字符串添加,HTML标签
# 为字符串添加HTML标签 import time def zhuang(fun): def zhaung_1(*args, **kargs): # time.sleep(1) html_str = ...
- No serializer found for class org.hibernate.proxy.pojo.bytebuddy.ByteBuddyInterceptor
使用jpa做增删改查的时候出现了这个异常,原因是转化成json的时候,fasterxml.jackson将对象转换为json报错,发现有字段为null 解决方案:实体类上添加 @JsonIgnoreP ...
- centos7 walle2瓦力部署教程
项目部署上线,如果是单服务器,那么有多种方式可以部署,比如直接ftp上传,或者直接git去拉取,人工操作也不会花费精力和时间,但是如果采用了集群模式,有多台服务器,那么依靠一台一台的去上传代码,就显得 ...
- Idea实用小Tips
设置keymap 自己根据习惯选择keymap(键位) 插件安装 ###省去set.get方法以及基于注解的日志框架 lombok plugin ###找bug用的 FindBugs-IDEA ### ...
- thinkphp中简单的控制器使用
1.在路由(route.php)中定义一条路由 Route::rule('new/:name/:id','index/News/read'); 2.在index下的controller控制器中新建一个 ...