JQuery实现一个轮播图
1、HTML
<div class="banner">
<div class="b_main">
<div class="b_m_pic">
<ul>
<li>
<a>
<img src="img/1.png" />
</a>
</li>
<li>
<a>
<img src="img/2.png" />
</a>
</li>
<li>
<a>
<img src="img/3.jpg" />
</a>
</li>
<li>
<a>
<img src="img/4.jpg" />
</a>
</li>
<li>
<a>
<img src="img/5.png" />
</a>
</li>
<li>
<a>
<img src="img/6.png" />
</a>
</li>
</ul>
</div>
</div>
<!--小圆点-->
<div class="b_list">
<ul>
<li class="l_click"></li>
<li></li>
<li></li>
<li></li>
<li></li>
<li></li>
</ul>
</div>
<div class="b_btn">
<div class="b_left"><</div>
<div class="b_right">></div>
</div>
</div>
2、CSS
<style type="text/css">
* {
margin: ;
padding: ;
} ul li {
list-style: none;
} img {
margin: ;
width: %; /*这里的宽高是为了占满盒子*/
height: %;
} .banner {
position: relative;
width: 1366px;
height: 780px;
margin: 100px auto;
border: 10px solid #;
border-radius: 15px;
} .banner .b_main {
position: relative;
width: 1366px;
height: 780px;
} .banner .b_main .b_m_pic {
position: relative;
width: 1366px;
height: 780px;
} .b_main .b_m_pic li {
position: absolute; /*这里给绝对定位,是为了把li叠在一起*/
width: 1366px;
height: 780px;
top: ;
left: ;
}
/*小圆点的样式*/
.b_list ul {
position: absolute; /*这里的ul根据banner定位*/
right: 40px;
bottom: 30px;
} .b_list ul li {
width: 20px;
height: 20px;
float: left;
background: #;
margin-left: 20px;
border-radius: 50px;
border: 2px solid white;
} .b_list ul .l_hover, .b_list ul .l_click {
border: 2px solid #;
background: white;
}
/*两边耳朵的样式*/
.b_btn div {
position: absolute;
width: 100px;
height: 100px;
background: rgba(,,,0.7);
font-size: 60px;
color: white;
text-align: center;
line-height: 100px;
top: %;
margin-top: -80px;
cursor: pointer;
}
/*移到左边*/
.b_btn .b_left {
left: ;
border-radius: %;
}
/*移到右边*/
.b_btn .b_right {
right: ;
border-radius: %;
}
</style>
3、JS
var $li = $(".b_list ul li");//获取.b_list里面的所有li,放到$li这个变量里面
var len = $li.length - ;
var _index = ;//li的索引
var $img = $(".b_main .b_m_pic li");//同上
var $btn = $(".b_btn div");
var timer = null; $li.hover(function () {
$(this).addClass("l_hover");//指向li添加样式
}, function () {
$(this).removeClass("l_hover");//指向li删除样式
}); //封装函数
function play() {
//获取li的下标,改变样式
$li.eq(_index).addClass("l_click").siblings().removeClass("l_click");
//获取图片的下标,实现淡入淡出
$img.eq(_index).fadeIn().siblings().fadeOut();
} //点击事件
$li.click(function () {
_index = $(this).index();
//获取li的下标,改变样式
//$li.eq(_index).addClass("l_click").siblings().removeClass("l_click");
//获取图片的下标,实现淡入淡出
//$img.eq(_index).fadeIn().siblings().fadeOut();
play();
}); //两边耳朵的点击事件
$btn.click(function () {
var index = $(this).index();
if (index) {
_index++;
if (_index > len) {
_index = ;
}
play();
} else {
_index--;
if (_index < ) {
_index = len;
}
play();
}
}); //定时轮播
function auto() {
//把定时器放进timer这个对象里面
timer = setInterval(function () {
_index++;
if (_index > len) {
_index = ;
}
play();
}, );
} auto(); //当我移上d_main的时候停止轮播
$(".b_main").hover(function () {
clearInterval(timer);
}, function () {
//移开重新调用播放
auto();
}); //当我移上两边耳朵的时候停止轮播
$(".b_btn div").hover(function () {
clearInterval(timer);
}, function () {
//移开重新调用播放
auto();
});
4、效果图
5、总结
① 图片、小圆点、两边的耳朵要使用position:absolute绝对定位,进行叠加。
注:绝对定位要根据父级元素进行定位,父级元素要加上position: relative;
② 根据索引值改变图片,达成切图
注:实现淡入淡出分别是fadeIn和fadeOut两个jq方法
siblings() 方法返回被选元素的所有同级元素。同级元素是共享相同父元素的元素。
③ 定时器(实现轮播):
setInterval()是开始播放,clearInterval()是关闭
定时器有两个参数,第一个是函数方法(可以另写一个方法,写上方法名调用,也可以直接写一个function),第二个是时间
JQuery实现一个轮播图的更多相关文章
- jQuery淡入淡出轮播图实现
大家好我是 只是个单纯的小白,这是人生第一次写博客,准备写的内容是Jquery淡入淡出轮播图实现,在此之前学习JS写的轮播图效果都感觉不怎么好,学习了jQuery里的淡入淡出效果后又写了一次轮播图效果 ...
- 用jQuery写的轮播图
效果图: GitHub地址:https://github.com/123456abcdefg/Javascript 大家可以下载源码查看. 与前一篇写的轮播图实现的效果一致,这个是用jQuery写的, ...
- 用纯css、JavaScript、jQuery简单的轮播图
完成一个可以自动切换或点击数字的轮播图 HTML代码只需要一个div 包含着一个图片和一个列表,我们主要的思路就是通过点击相应的数字,改变图片的 路径. 有4张图片都在img文件夹里,名称为 img ...
- jQ实现的一个轮播图
众所周知,轮播图是被广泛的运用的. 轮播图我们在很多的网站上都可以看到,例如淘宝.京东这些网站都很常见. 下面开始我们的轮播之旅: 搭建我们的骨架: <!DOCTYPE html> < ...
- css3 - 纯css实现一个轮播图
这是我上一次的面试题.一晃两个月过去了. 从前都是拿原理骗人,把怎么实现的思路说出来. 我今天又被人问到了,才想起来真正码出来.码出来效果说明一切: 以上gif,只用到了5张图片,一个html+css ...
- jQuery实现简易轮播图的效果
(图片素材取自于小米官网) 刚开始接触jQuery的学习,个人觉得如果为了实现多数的动态效果,jQuery的确很简易方便. 下面简易的轮播图效果,还请前辈多多指教~ (努力学习react vue an ...
- 记录一下自己用jQuery写的轮播图
<!DOCTYPE html> <html> <head> <meta charset="utf-8"> <title> ...
- jquery淡入淡出轮播图
<!DOCTYPE html> <html> <head lang="en"> <meta charset="UTF-8&quo ...
- AXURE 8弄一个轮播图的步骤
这个图是网上找到,7.0可以使用. 如果是8.0.没有找到"动态面板"这个地方,如下图所示
随机推荐
- 五种ip proxy的设置方法
我们在制作爬虫爬取想要的资料时,由于是计算机自动抓取,强度大.速度快,通常会给网站服务器带来巨大压力,所以同一个IP反复爬取同一个网页,就很可能被封,在这里介绍相关的技巧,以免被封:但在制作爬虫时,还 ...
- Django-DRF-图书增删改查 !!!
自己封装的 class MyResponse(): def __init__(self): self.status = 100 self.msg = None @property def get_ ...
- 安装和启动tftp-server服务器及可能出现Redirecting to /bin/systemctl restart xinetd.service问题的解决方式
安装和启动tftp-server服务器及可能出现Redirecting to /bin/systemctl restart xinetd.service问题的解决方式 1)首先,检查服务器已安装的tf ...
- 安装 Docker <一>
一.docker简介 Docker 是一个开源的应用容器引擎,让开发者可以打包他们的应用以及依赖包到一个可移植的容器中,然后发布到任何流行的Linux机器上,也可以实现虚拟化,容器是完全使用沙箱机制, ...
- net core体系-web应用程序-4asp.net core2.0 项目实战(1)-13基于OnActionExecuting全局过滤器,页面操作权限过滤控制到按钮级
1.权限管理 权限管理的基本定义:百度百科. 基于<Asp.Net Core 2.0 项目实战(10) 基于cookie登录授权认证并实现前台会员.后台管理员同时登录>我们做过了登录认证, ...
- fillder---工具栏隐藏/显示
显示隐藏工具栏方法:view---show toolbar
- 查找已连接过的wifi密码
无意之间看到能破解已连接过的wifi密码的诀窍,赶紧存储下来. 1. 首先打开终端 2. 在没有网路的情况下输入: netsh wlan show profiles 结果如下(自己的): 这些‘用户配 ...
- [Educational Round 5][Codeforces 616F. Expensive Strings]
这题调得我心疲力竭...Educational Round 5就过一段时间再发了_(:з」∠)_ 先后找了三份AC代码对拍,结果有两份都会在某些数据上出点问题...这场的数据有点水啊_(:з」∠)_[ ...
- 【LookLook文档】通过less 定制自己的Bootstrap 样式
闲话 学习还是看文档最快,看文档要仔细点,不可走马观花.感谢 “Bootstrap中文网” 思路 1.早在2015开始接触,由于公司中使用的是easyui 固一直没完全使用Bootstrap,开始接触 ...
- QQ设置手机和pc qq群消息不同步
作为开发人员QQ群很多,很正常,工作的时候才需要看qq信息和群消息,但是蛋疼qq在新版的qq必须设置同步,之前用的qq8.1版本可以设置不同步,但是现在突然不行 目前可以用的途径就是 QQ国际PC版2 ...