jquery实现轮播图效果


Posted in Javascript onFebruary 13, 2017

效果如下:

jquery实现轮播图效果

代码如下:

<!DOCTYPE html>
<html lang="en">
<head>
 <meta charset="UTF-8">
 <title>slider</title>
 <style type="text/css">
 *{
 margin: 0;
 padding: 0;
 }
 #slideshow{
 position: relative;
 width: 512px;
 height: 384px;
 margin: 0 auto;
 overflow: hidden;
 }
 #slideshow>ul,#slideshow>ul>li,#slideshow-nav{
 position: absolute;
 }
 #slideshow>ul>li{
 list-style: none;
 }
 #slideshow-nav{
 bottom: 20px;
 width: 100%;
 text-align: center;
 }
 #slideshow-nav>span{
 display: inline-block;
 width: 15px;
 height: 15px;
 margin: 0 7px;
 font-size: 0;
 background-color: rgba(255,255,255,.3);
 border-radius: 50%;
 user-select: none;
 -webkit-user-select: none;
 transition: all .5s;
 -webkit-transition: all .5s;
 cursor: pointer;
 }
 #slideshow-nav>span.active{
 background-color: #fff;
 }
 </style>
</head>
<body>
 <div id="slideshow">
 <ul>
 <li><img src="http://cdn.attach.qdfuns.com/notes/pics/201611/26/231154e8ab2zanwd59a2w2.jpg" alt="gakki is mine"></li>
 <li><img src="http://cdn.attach.qdfuns.com/notes/pics/201611/26/231236ugj2glgcl6g66gg4.jpg" alt="gakki is mine"></li>
 <li><img src="http://cdn.attach.qdfuns.com/notes/pics/201611/26/231236c26bx5bbfp6kazzm.jpg" alt="gakki is mine"></li>
 <li><img src="http://cdn.attach.qdfuns.com/notes/pics/201611/26/231236oqd8i8q158ojr0i7.jpg" alt="gakki is mine"></li>
 <li><img src="http://cdn.attach.qdfuns.com/notes/pics/201611/26/231236o1iud19lkz11wqja.jpg" alt="gakki is mine"></li>
 </ul>
 <div id="slideshow-nav"></div>
 </div>
 <script src="http://cdn.bootcss.com/jquery/3.1.1/jquery.min.js"></script>
 <script type="text/javascript">
 $(function(){
 var timer = null,
 curindex = 0,
 duration = 2000,
 speed = 500;
 var $imgWrap = $('#slideshow>ul');
 var totalIndex = $imgWrap.find('li').length;
 var width = $('#slideshow').width();
 //insert navigate span, let img in order
 $('#slideshow').find('ul>li').each(function(index){
 $(this).css('left', width*index + 'px');
 $('#slideshow-nav').append('<span>' + (index+1) + '</span>');
 })
 //
 $('#slideshow-nav>span').eq(0).addClass('active');
 //auto slide
 var move = function(){
 curindex += 1;
 if (curindex===totalIndex) {
 curindex = 0;
 }
 // current span add classname "active"
 $('#slideshow-nav>span').each(function(index) {
 $(this).removeClass('active')
 }).eq(curindex).addClass('active');
 //auto slide
 $imgWrap.animate({
 'left': width*curindex*(-1)+'px',
 }, speed)
 //一开始没加"timer = ",这个bug耽误了不少时间
 timer = setTimeout(move,duration+speed);
 };
 //init
 timer = setTimeout(move,duration);
 //click event
 $('#slideshow-nav>span').on('click', function(event) {
 event.preventDefault();
 /* Act on the event */
 clearTimeout(timer);
 $imgWrap.stop(true, true);
 curindex = $(this).index() - 1;
 move();
 });
 })
 </script>
</body>
</html>

以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,同时也希望多多支持三水点靠木!

Javascript 相关文章推荐
(JS实现)MapBar中坐标的加密和解密的脚本
May 16 Javascript
锋利的jQuery 要点归纳(三) jQuery中的事件和动画(上:事件篇)
Mar 24 Javascript
js操作table示例(个人心得)
Nov 29 Javascript
在JavaScript中操作数组之map()方法的使用
Jun 09 Javascript
输入框点击时边框变色效果的实现方法
Dec 26 Javascript
详解angular2实现ng2-router 路由和嵌套路由
Mar 24 Javascript
微信小程序中顶部导航栏的实现代码
Mar 30 Javascript
利用node.js制作命令行工具方法教程(一)
Jun 22 Javascript
对于input 框限定输入值为浮点型的js代码
Sep 25 Javascript
vue-cli3使用 DllPlugin 实现预编译提升构建速度
Apr 24 Javascript
vue视频播放暂停代码
Nov 08 Javascript
支付宝小程序实现省市区三级联动
Jun 21 Javascript
JS中解决谷歌浏览器记住密码输入框颜色改变功能
Feb 13 #Javascript
利用Javascript实现简单的转盘抽奖
Feb 13 #Javascript
简单实现js倒计时功能
Feb 13 #Javascript
基于node.js依赖express解析post请求四种数据格式
Feb 13 #Javascript
js中小数向上取整数,向下取整数,四舍五入取整数的实现(必看篇)
Feb 13 #Javascript
Angularjs自定义指令实现三级联动 选择地理位置
Feb 13 #Javascript
基于jQuery代码实现圆形菜单展开收缩效果
Feb 13 #Javascript
You might like
PHP图片验证码制作实现分享(全)
2012/05/10 PHP
浅析SVN常见问题及解决方法
2013/06/21 PHP
php将金额数字转化为中文大写
2015/07/09 PHP
PHP PDOStatement::errorInfo讲解
2019/01/31 PHP
JAVASCRIPT  THIS详解 面向对象
2009/03/25 Javascript
用方法封装javascript的new操作符(一)
2010/12/25 Javascript
基于jQuery实现在线选座之高铁版
2015/08/24 Javascript
轻松实现JavaScript图片切换
2016/01/12 Javascript
html+js实现简单的计算器代码(加减乘除)
2016/07/12 Javascript
jQuery实现字符串全部替换的方法【推荐】
2017/03/09 Javascript
常用的js方法合集
2017/03/10 Javascript
vue.js之vue-cli脚手架的搭建详解
2017/05/05 Javascript
JQuery Ajax 异步操作之动态添加节点功能
2017/05/24 jQuery
vue中appear的用法
2017/08/17 Javascript
JQueryDOM之样式操作
2019/03/27 jQuery
vue-cli webpack配置文件分析
2019/05/20 Javascript
js实现跟随鼠标移动的小球
2019/08/26 Javascript
python用Pygal如何生成漂亮的SVG图像详解
2017/02/10 Python
Python统计一个字符串中每个字符出现了多少次的方法【字符串转换为列表再统计】
2019/05/05 Python
Python 使用list和tuple+条件判断详解
2019/07/30 Python
利用pyshp包给shapefile文件添加字段的实例
2019/12/06 Python
Django多进程滚动日志问题解决方案
2019/12/17 Python
keras导入weights方式
2020/06/12 Python
keras topN显示,自编写代码案例
2020/07/03 Python
HTML5 Canvas实现文本对齐的方法总结
2016/03/24 HTML / CSS
HTML5里的placeholder属性使用实例和美化显示效果的方法
2014/04/23 HTML / CSS
Levi’s美国官网:美国著名的牛仔裤品牌
2016/08/19 全球购物
澳大利亚设计师服装在线:MISHA
2019/10/07 全球购物
linux面试题参考答案(6)
2014/08/29 面试题
销售实习自我鉴定
2013/12/07 职场文书
关于保护环境的建议书
2014/08/26 职场文书
关于清明节的演讲稿2015
2015/03/18 职场文书
2015秋季开学典礼演讲稿
2015/07/16 职场文书
jdbc使用PreparedStatement批量插入数据的方法
2021/04/27 MySQL
Python中requests做接口测试的方法
2021/05/30 Python
MyBatis配置文件解析与MyBatis实例演示
2022/04/07 Java/Android