jquery实现导航图轮播
版权声明:作者原创,转载请注明出处!
下面的几个栗子是使用jquery实现Banner轮播的效果,直接将代码贴出来,从最初级没有任何优化和封装的写法,一直到最后一个栗子,一步步进行了优化,加大程序的可复用性,减少代码冗余。
栗子①
HTML布局:注:图片请自己准备,大小为(W:200px H:200px)
//最外层容器DIV
<div id="wrap">
//图片容器UL
<ul id="imgWrap">
<li id="one"><img src="img/1.1.jpg" /></li>
<li><img src="img/1.jpg" /></li>
<li><img src="img/2.jpg" /></li>
<li><img src="img/3.jpg" /></li>
</ul>
//按钮容器OL
<ol id="numWrap">
<li class="color"></li>
<li></li>
<li></li>
<li></li>
</ol>
//左右按钮
<div id="left"></div>
<div id="right"></div>
</div>
CSS样式:注:一些较为特殊的样式已经进行说明,请仔细阅读每一个样式添加的意义
* {
margin:;
padding:;
outline:;
border:;
}
li {
list-style: none;
}
#wrap {
width: 200px;
height: 200px;
margin: 10px auto;
overflow: hidden; /*溢出部分隐藏*/
position: relative;
}
#imgWrap {
width: 200px; /*图片容器固定一张图片宽高,在JS里使用代码进行动态控制具体宽、高*/
height: 200px;
position: absolute;
top:;
left:;
transition: all .8s ease; /*设置动画*/
}
#imgWrap li {
float: left;
}
#numWrap {
position: absolute;
bottom: 10px;
right: 10px;
}
#numWrap li {
width: 10px;
height: 10px;
background: #ccc;
border-radius: 50px;
float: left;
margin: 5px;
}
#numWrap li.color { /*准备class样式*/
background: red;
}
#left,
#right {
width: 15px;
height: 20px;
background: #CCCCCC;
position: absolute;
top: 40%;
display: none;
}
#left {
left: 10px;
}
#right {
right: 10px;
}
#wrap:hover #left {
display: block;
}
#wrap:hover #right { /*鼠标移入显示左右按钮*/
display: block;
}
jquery和javascript代码:注:请在<head>标签中提前引入jquery文件
$(function() {
var index = 0;
//将图片的UL宽度撑大
$("#imgWrap").css('width', $('#imgWrap li').width() * $("#imgWrap li").length);
$("#numWrap li").click(function() {
//循环清空
$("#numWrap li").removeClass("color");
//只给点击按钮添加class
$(this).addClass("color");
//点击按钮,显示对应图片
index = $(this).index();
$("#imgWrap").css('left', -$('#imgWrap li').width() * index);
});
$("#left").click(function() {
//下标--,才会等于-1
index--;
if(index == -1) {
index = $('#imgWrap li').length - 1;
};
$("#numWrap li").removeClass("color");
$("#numWrap li").eq(index).addClass("color");
$("#imgWrap").css('left', -$('#imgWrap li').width() * index);
});
$("#right").click(function() {
//下标++,才会等于长度
index++;
if(index == $('#imgWrap li').length) {
index = 0;
};
$("#numWrap li").removeClass("color");
$("#numWrap li").eq(index).addClass("color");
$("#imgWrap").css('left', -$('#imgWrap li').width() * index);
});
//开启定时器
var timer = setInterval(function() {
index++;
if(index == -1) {
index = $('#imgWrap li').length - 1;
} else if(index == $('#imgWrap li').length) {
index = 0;
};
$("#numWrap li").removeClass("color");
$("#numWrap li").eq(index).addClass("color");
$("#imgWrap").css('left', -$('#imgWrap li').width() * index);
}, 2000);
//鼠标移入、移出关闭、开启定时器
$("#wrap").hover(function() {
clearInterval(timer);
}, function() {
timer = setInterval(function() {
index++;
if(index == -1) {
index = $('#imgWrap li').length - 1;
} else if(index == $('#imgWrap li').length) {
index = 0;
};
$("#numWrap li").removeClass("color");
$("#numWrap li").eq(index).addClass("color");
$("#imgWrap").css('left', -$('#imgWrap li').width() * index);
}, 2000);
});
});
效果图:
栗子② 注:HTML、css布局及样式同栗子①
jquery及javascript代码
$(function() {
var index = 0;
//将图片的UL宽度撑大
$("#imgWrap").css('width', $('#imgWrap li').width() * $("#imgWrap li").length);
//按钮点击
$("#numWrap li").click(function() {
index = $(this).index();
next();
});
$("#left").click(function() {
//下标--,才会等于-1
index--;
next();
});
$("#right").click(function() {
//下标++,才会等于长度
index++;
next();
});
//优化成函数,使用时可以再各处直接调用
function next() {
if(index == -1) {
index = $('#imgWrap li').length - 1;
} else if(index == $('#imgWrap li').length) {
index = 0;
};
//循环清空
$("#numWrap li").removeClass("color");
//只给点击按钮添加class
$("#numWrap li").eq(index).addClass("color");
//点击按钮,显示对应图片
$("#imgWrap").css('left', -$('#imgWrap li').width() * index);
};
//开启定时器
var timer = setInterval(function() {
index++;
next();
}, 2000);
//鼠标移入和移出事件清除、开启定时器
$("#wrap").hover(function() {
clearInterval(timer);
}, function() {
//不要写var,否则会开启两次定时器
timer = setInterval(function() {
index++;
next();
}, 2000);
});
});
栗子②主要是对栗子①进行了优化,将重复性代码,放到了next函数里,进行多次调用,程序得到大幅度代码的优化,提高了程序的可复用性。下面我们进行函数的封装,封装好的函数可以的到最大程度的可复用性,相同功能,只需调用相应函数,传入不同参数即可完成,不需要再重新编写相同功能的程序,怎么样,似不似很期待,^_^
栗子③
HTML代码:
<div class="wrap" id="wrap1">
<ul class="imgWrap" id="imgWrap1">
<li class="one"><img src="img/1.1.jpg" /></li>
<li><img src="img/1.2.jpg" /></li>
<li><img src="img/1.3.jpg" /></li>
<li><img src="img/1.4.jpg" /></li>
</ul>
<ol class="numWrap" id="numWrap1">
<li class="color"></li>
<li></li>
<li></li>
<li></li>
</ol>
<div class="left" id="left1"></div>
<div class="right" id="right1"></div>
</div> <div class="wrap" id="wrap2">
<ul class="imgWrap" id="imgWrap2">
<li class="one"><img src="img/1.1.jpg" /></li>
<li><img src="img/1.2.jpg" /></li>
<li><img src="img/1.3.jpg" /></li>
<li><img src="img/1.4.jpg" /></li>
</ul>
<ol class="numWrap" id="numWrap2">
<li class="color"></li>
<li></li>
<li></li>
<li></li>
</ol>
<div class="left" id="left2"></div>
<div class="right" id="right2"></div>
</div>
这个布局里写了两个要进行轮播的导航,目的是展示程序的可重复使用性
css代码:
* {
margin:;
padding:;
outline:;
border:;
}
li {
list-style: none;
}
.wrap {
width: 200px;
height: 200px;
margin: 10px auto;
overflow: hidden;
position: relative;
}
.imgWrap {
width: 200px;
height: 200px;
position: absolute;
top:;
left:;
transition: all .8s ease;
}
.imgWrap li {
float: left;
}
.numWrap {
position: absolute;
bottom: 10px;
right: 10px;
}
.numWrap li {
width: 10px;
height: 10px;
background: #ccc;
border-radius: 50px;
float: left;
margin: 5px;
}
.numWrap li.color {
background: red;
}
.left,
.right {
width: 15px;
height: 20px;
background: #CCCCCC;
position: absolute;
top: 40%;
display: none;
}
.left {
left: 10px;
}
.right {
right: 10px;
}
.wrap:hover .left {
display: block;
}
.wrap:hover .right {
display: block;
}
jquery和javascript代码:
$(function() {
//调用
Tab($("#wrap1"),$("#imgWrap1"),$('#imgWrap1 li'),$("#numWrap1 li"),$("#left1"),$("#right1"));
Tab($("#wrap2"),$("#imgWrap2"),$('#imgWrap2 li'),$("#numWrap2 li"),$("#left2"),$("#right2"));
});
//封装成函数
//$("#wrap"),$("#imgWrap"),$('#imgWrap li'),$("#numWrap li"),$("#left"),$("#right")
function Tab(wrap,imgWrap,imgLi,numLi,left,right) {
var index = 0;
//将图片的UL宽度撑大
imgWrap.css('width', imgLi.width() * imgLi.length);
//按钮点击
numLi.click(function() {
index = $(this).index();
next();
});
left.click(function() {
//下标--,才会等于-1
index--;
next();
});
right.click(function() {
//下标++,才会等于长度
index++;
next();
});
//优化成函数,使用时可以再各处直接调用
function next() {
if(index == -1) {
index = imgLi.length - 1;
} else if(index == imgLi.length) {
index = 0;
};
//循环清空
numLi.removeClass("color");
//只给点击按钮添加class
numLi.eq(index).addClass("color");
//点击按钮,显示对应图片
imgWrap.css('left', -imgLi.width() * index);
};
//开启定时器
var timer = setInterval(function() {
index++;
next();
}, 2000);
//鼠标移入和移出事件清除、开启定时器
wrap.hover(function() {
clearInterval(timer);
}, function() {
//不要写var,否则会开启两次定时器
timer = setInterval(function() {
index++;
next();
}, 2000);
});
};
效果图:
到这里,就结束啦,具体有什么需要注意的地方,我都已经在代码的注释里写的很明确了,如果大家有更好的方法,欢迎与我交流,共同成长和进步!
入我有理解的不正确的地方,欢迎各位大神批评指正,谢谢
jquery实现导航图轮播的更多相关文章
- jQuery个性化图片轮播效果
jQuery个性化图片轮播效果 购物产品展示:图片轮播器<效果如下所示> 思路说明: 每隔一段时间,实现图片的自动切换及选项卡选中效果,鼠标划入图片动画停止,划出或离开动画开始 两个区域: ...
- PgwSlideshow-基于Jquery的图片轮播插件
0 PgwSlideshow简介 PgwSlideshow是一款基于Jquery的图片轮播插件,基本布局分为上下结构,上方为大图轮播区域,用户可自定义图片轮播切换的间隔时间,也可以通过单击左右方向按键 ...
- jQuery.YesShow - 图片轮播插件(带图片放大功能)
jQuery.YesShow - 图片轮播插件(带图片放大功能) 使用简单,原文件只要这样就可以了:<div id="yes"> <ul> ...
- 自适应图片宽度的jQuery焦点幻灯轮播代码
自适应图片宽度的jQuery焦点幻灯轮播代码 注意要1.7.2版本的jq才支持点击后显示点击的图片,不然就是一直顺序播放 演示 XML/HTML Code <div id="sli ...
- jQuery补充,基于jQuery的bxslider轮播器插件
基于jQuery的bxslider轮播器插件 html <!DOCTYPE html> <html lang="zh-cn"> <head> & ...
- (转)jquery实现图片轮播
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/ ...
- jQuery五屏轮播手风琴切换代码
jQuery五屏轮播手风琴切换代码 在线演示本地下载
- jQuery淡入淡出轮播图实现
大家好我是 只是个单纯的小白,这是人生第一次写博客,准备写的内容是Jquery淡入淡出轮播图实现,在此之前学习JS写的轮播图效果都感觉不怎么好,学习了jQuery里的淡入淡出效果后又写了一次轮播图效果 ...
- JQuery实现图片轮播效果源码
======================整体结构======================== <div class="banner"> <ul class ...
随机推荐
- 2014 年最热门的国人开发开源软件 TOP 100 - 开源中国社区
不知道从什么时候开始,很多一说起国产好像就非常愤慨,其实大可不必.做开源中国六年有余,这六年时间国内的开源蓬勃发展,从一开始的使用到贡献,到推出自己很多的开源软件,而且还有很多软件被国外的认可.中国是 ...
- 前端工程师技能之photoshop巧用系列第一篇——准备篇
× 目录 [1]作用 [2]初始化 [3]常用工具[4]快捷键 前面的话 photoshop是前端工程师无法回避的一个软件,这个软件本身很强大,但我们仅仅需要通过这个工具来完成基本的切图工作即可.本文 ...
- 【开源】OSharp框架解说系列(3):扩展方法
OSharp是什么? OSharp是个快速开发框架,但不是一个大而全的包罗万象的框架,严格的说,OSharp中什么都没有实现.与其他大而全的框架最大的不同点,就是OSharp只做抽象封装,不做实现.依 ...
- MySQL学习笔记十一:数据导入与导出
数据导入 1.mysqlimport命令行导入数据 在使用mysqlimport命令导入数据时,数据来源文件名要和目标表一致,不想改文件名的话,可以复制一份创建临时文件,示例如下. 建立一个文本use ...
- 在Linux客户机与Windows宿主机之间建立共享(VitrualBox)
VirtualBox中,如果客户机和宿主机都是Windows的话,共享相对是比较方便的.一般是通过\\vboxsvr\shared 这样的路径访问即可. 但是如果客户机是Linux的话,就略微麻烦一点 ...
- iOS开发之窥探UICollectionViewController(一) -- Ready Your CollectionViewController
之前用CollectionViewController只是皮毛,一些iOS从入门到精通的书上也是泛泛而谈.这几天好好的搞了搞苹果的开发文档上CollectionViewController的内容,亲身 ...
- windows配置xhprof,PHP性能分析工具
本来以为配置这么一个工具不会费很大的力气,后面发现完全不是. 一.小插曲 早上显示电脑不能显示虚拟目录下的所有域名,但是能打开localhost,数据库连接也不行了.这个问题纠缠了我一个上午.对了还有 ...
- 软件工程-构建之法 理解C#一小段程序
一.前言 老师给出的要求: 阅读下面程序,请回答如下问题: 问题1:这个程序要找的是符合什么条件的数? 问题2:这样的数存在么?符合这一条件的最小的数是什么? 问题3:在电脑上运行这一程序,你估计多长 ...
- AGS中通过FeatureServer插入数据失败、插入数据在WMTS请求中无法显示以及version概念的讨论
文章版权由作者李晓晖和博客园共有,若转载请于明显处标明出处:http://www.cnblogs.com/naaoveGIS/. 1.背景 在多个项目中,当我方接口给其他部门人员使用时出现了插入数据失 ...
- DotNet中几种常用的加密算法
在.NET项目中,我们较多的使用到加密这个操作.因为在现代的项目中,对信息安全的要求越来越高,那么多信息的加密就变得至关重要.现在提供几种常用的加密/解密算法. 1.用于文本和Base64编码文本的互 ...