原生js封装轮播图

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

slide.js
/*
* 轮播图
*/ function Slide(elem, ms, d, ind){
this.el = elem;
this.w = parseInt(getStyle(elem, "width"));
this.h = parseInt(getStyle(elem, "height"));
var a = this.el.children;
this.ul = a[0];
this.ol = a[1];
this.lBtn = a[2];
this.rBtn = a[3];
this.olspan = this.ol.getElementsByTagName("span");
this.l = this.olspan.length;
this.ul.style.width = this.w*(this.l+1)+"px"; // ul的宽度
this.lBtn.style.top = this.rBtn.style.top = (this.h-this.rBtn.offsetHeight)/2+"px";
this.ms = ms; // 每隔多久执行一次滚动
this.d = d; // 轮播时方向 this.ul.innerHTML += this.ul.children[0].outerHTML; //将第一张图片复制到最后一个位置上 var that = this; this.now = ind;
that.prev = -that.now*that.w; this.run = function(){
var i=0, l=that.l, btns=that.olspan, btn;
for( ; i<l; i++){
btn = btns[i];
btn.i = i;
btn.onclick = function(){
that.now = this.i;
that.tab();
}
} that.timer = setInterval(that.next, that.ms);
that.el.onmouseover = that.over;
that.el.onmouseout = that.out;
that.lBtn.onclick = function(){
that.now--;
that.d = -1;
that.tab();
}
that.rBtn.onclick = function(){
that.now++;
that.d = 1;
that.tab();
}
that.lBtn.onmousedown = that.rBtn.onmousedown = function(){
return false;
}
} this.tab = function(){
that.ul.style.left = that.prev+"px"; // 每次运动时,先瞬间定位到上一次的目标值,然后再执行本次运动 if( that.now == that.l ){
that.prev = 0;
startMove(that.ul, {"left":-that.now*that.w}, function(){
that.ul.style.left = "0px";
});
that.now = 0;
}else if( that.now == -1 ){
that.now = that.l-1;
that.ul.style.left = -that.l*that.w+"px";
that.prev = -that.now*that.w;
startMove(that.ul, {"left":that.prev});
}else{
that.prev = -that.now*that.w;
startMove(that.ul, {"left":that.prev});
} // 样式
for( var i=0,l=that.l; i<l; i++ ){
that.olspan[i].className = "";
}
that.olspan[that.now].className = "selected";
} this.next = function(){
that.now += that.d;
that.tab();
} this.over = function(){
clearInterval(that.timer);
startMove(that.lBtn, {"opacity":100});
startMove(that.rBtn, {"opacity":100});
}
this.out = function(){
that.timer = setInterval(that.next, that.ms);
startMove(that.lBtn, {"opacity":0});
startMove(that.rBtn, {"opacity":0});
} this.tab();
this.run();
}
startMove.js(运动函数)
/*
* 运动函数
* 参数:
* elem 指操作的元素
* obj 指操作的元素节点上的css属性及它的目标值
* attr 指操作的元素节点上的css属性
* target 指操作的元素节点上的css属性的目标值
* fn 指运动函数执行完,执行哪一个函数
*/
function startMove(elem, obj, fn){
// 清除定时器
clearInterval(elem.timer);
// 多属性同时运动时,是否每一个属性都到了目标值
// 开启定时器
elem.timer = setInterval(function(){
var flag = true; // 默认时认为到了目标值
// 支持多属性同时运动
for( var attr in obj ){
// 目标值
var target = obj[attr];
// 判断属性是否为透明度
var v; // 获取当前值
if( attr == "opacity" ){
v = getStyle(elem, attr);
v = Math.round(v*100);
}else{
v = parseInt(getStyle(elem, attr));
}
//console.log(v);
// 目标值与当前值的间距
var dist = target - v;
// 求步长
var speed = dist/6;
// 步长取整数
if(speed>0){
speed = Math.ceil(speed);
}else{
speed = Math.floor(speed);
}
// 更新
if( attr == "opacity" ){
elem.style.opacity = (v+speed)/100;
if(/MSIE/.test(navigator.userAgent)){// 如果当前浏览器为IE,则执行兼容代码
elem.style.filter = "alpha(opacity="+(v+speed)+")"; // 兼容低版本IE
}
}else{
elem.style[attr] = v+speed+"px";
}
// 如果没有到达目标值
if(v!=target){
flag = false;
}
//console.log(0);
}
// 如果已经到达目标值,则停止定时器
if( flag ){
clearInterval(elem.timer);
if( fn ){ // 如果给定了第三个参数,则执行该函数
fn();
}
}
}, 50); } /*
* 获取行间样式
*/
function getStyle(elem, attr){
if( window.getComputedStyle ){
return getComputedStyle(elem, null)[attr];
}else{
return elem.currentStyle[attr];
}
}
接下来是一些简单的css代码
/*
* 轮播图
*/ .slide{
position: relative;
overflow: hidden;
}
.slide *{
margin: 0;
padding: 0;
}
.slide li{
float: left;
list-style: none;
}
.slide>ul{
position: absolute;
left: 0;
top: 0;
}
.slide>ul>li{ }
.slide>ol{
position: absolute;
right: 0;
bottom: 0;
}
.slide>ol>li{
padding: 10px;
}
.slide>ol>li>span{
display: block;
width: 20px;
height: 20px;
border-radius: 10px;
background: white;
cursor: pointer;
}
.slide .selected{
background: greenyellow;
} .slide>p{
position: absolute;
display: block;
width: 30px;
height: 30px;
text-align: center;
line-height: 25px;
border-radius: 15px;
background: white;
cursor: pointer;
opacity: 0;
}
.slide>p:hover{
background: greenyellow;
}
.slide>p:nth-child(3){
left: 10px;
}
.slide>p:nth-child(4){
right: 10px;
}
使用方法
<div id="div1" class="slide">
<ul>
<li><img src="img/001.jpg"/></li>
<li><img src="img/002.jpg"/></li>
<li><img src="img/003.jpg"/></li>
<li><img src="img/004.jpg"/></li>
</ul>
<ol>
<li><span></span></li>
<li><span></span></li>
<li><span></span></li>
<li><span></span></li>
</ol>
<p>&lt;</p>
<p>&gt;</p>
</div> 接下来在script中直接new一个实例,new Slide(div1, 3000, 1, 1);就可以实现轮播效果

代码很简单,细心观察,你也是大神

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

  1. 原生js封装轮播图

    个人实际开发中用到的效果问题总结出来便于自己以后开发查看调用,如果也适用其他人请随意拿走勿喷就行! 原生js对于思路要求比较高,在js代码我都写有备注,足够理解并使用,即使是小白或者刚入行的程序员也比 ...

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

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

  3. 原生js焦点轮播图

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

  4. 原生js实现轮播图

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

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

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

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

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

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

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

  8. 原生JS设计轮播图

    一.效果预览: 由于只能上传2M以下的图片,这里只截取了自动切换的效果: 二.编写语言 HTML.CSS.原生JS 三.编写思路 (一)HTML部分 1..slide意为滑槽,里面存放所有图片: 2. ...

  9. 授人以渔式解析原生JS写轮播图

    需求与分析 需求:循环无缝自动轮播五张图,按左右箭头可以手动切换图片,鼠标点击轮播图下面按钮 1 2 3 4 5会跳转到对应的第1 2 3 4 5张图片.鼠标放到轮播图的图片上时不再自动轮播并且左右箭 ...

随机推荐

  1. java 面试2019

    [第一部分] 面试要领[第1题] 流程必知必会[第2题] JDK源码[第二部分] 类和对象[第二篇] 面向对象基础[第1题] 面向对象是什么?[第2题] 类加载的过程[第3题] 类加载器有哪些[第4题 ...

  2. pandas读取xlsx

    一.使用pandas读取xlsx 引用pandas库 import pandas as pd pd.read_excel(path, sheet_name=0, header=0, names=Non ...

  3. 防HTTP慢速攻击的nginx安全配置

    概述   慢速攻击,是一种ddos攻击的变体版本.通常来说,它通过向服务器发送正常的请求,只不过请求的头或者请求体的内容特别长,发送速度有特别慢,这样每一个连接占用的时间就会变得特别长,攻击者会在短时 ...

  4. flyway 管理数据库版本

    Flyway 和 Liquibase 都是 Java 项目中常用的 DB migration 工具, 从使用简便性看,Flyway 比 Liquibase 更简单, 从 github 的 star 数 ...

  5. JavaScript学习笔记之CSS-DOM

    HTML负责结构层,网页的结构层由HTML或者XHTML之类的标记语言负责构建 CSS负责表示层,描述页面内容应该如何呈现. JavaScript负责行为层,负责内容应该如何响应事件这一问题. 能利用 ...

  6. thinkphp 输入过滤

    永远不要相信客户端提交的数据,所以对于输入数据的过滤势在必行,我们建议: 开启令牌验证避免数据的重复提交: 使用自动验证和自动完成机制进行初步过滤: 使用系统提供的I函数获取用户输入数据: 对不同的应 ...

  7. 解析Tomcat之HttpServlet详解

    解析Tomcat之HttpServlet详解 Servlet的框架是 由两个Java包组成:javax.servlet和javax.servlet.http. 在javax.servlet包中定义了所 ...

  8. Elasticsearch集群状态查看命令

    _cat $ curl localhost:9200/_cat=^.^=/_cat/allocation/_cat/shards/_cat/shards/{index}/_cat/master/_ca ...

  9. weblogic重置控制台密码

    1.备份文件如下文件 %DOMAIN_HOME%/security/DefaultAuthenticatorInit.ldift 2.进入%DOMAIN_HOME%/security目录,执行下列命令 ...

  10. delphi windows操作

    输入 procedure TypeKeyString(s: string); var c: Char; i: integer; off: integer; vkw: Word; begin to Le ...