Welcome 微信登录

首页 / 脚本样式 / JavaScript / jQuery实现宽屏图片轮播实例教程

本文实例讲述了jQuery实现宽屏图片轮播实例教程。分享给大家供大家参考。具体如下:
运行效果截图如下:


引入jquery库

<script src="js/jquery-1.9.1.min.js" type="text/javascript"></script>

构建html
整个代码分为三部分:

1、加载部分loadding ;

2、图片部分,这里图片只能是4张,有心的朋友再改良下吧;

3、TAB按钮部分,当然这里也只能是4个按钮,也需要改进。

<div class="gg" id="gg"><div class="ggLoading"><div class="ggLoading2"><em>精彩活动载入中</em></div></div><div class="ggs"><div class="ggBox" id="ggBox"><a href="#" title="5月22日测试开启领报名资格" style="z-index: 3; opacity: 4;"><img src="images/1.jpg" alt="" /></a><a href="#" title="首测世界的雕琢篇章开启"><img src="images/2.jpg" alt="" /></a><a href="#" title="上古世纪游戏资料手册"><img src="images/3.jpg" alt="" /></a><a href="#" title="游戏四大特色揭晓"><img src="images/4.jpg" alt="" /></a></div></div><div class="ggb"><div class="ggBtns" id="ggBtns"><a title="5月22日测试开启领报名资格" href="javascript:void(0)" class="ggOn"><em>5月22日测试开启领报名资格</em></a><a title="首测世界的雕琢篇章开启" href="javascript:void(0)"><em>首测世界的雕琢篇章开启</em></a><a title="上古世纪游戏资料手册" href="javascript:void(0)"><em>上古世纪游戏资料手册</em></a><a title="游戏四大特色揭晓" href="javascript:void(0)"><em>游戏四大特色揭晓</em></a></div></div></div>

CSS样式
这里的CSS可以根据项目需求自定义,不必拘泥于下面的代码,只要弄懂其中的原理就OK了。若你看不懂下面的CSS的话就恶补下吧,在此就不一一讲解了。

.ggLoading, .ggLoading2 {background-image: url(../images/nav.png);}.gg {width: 100%;height: 500px;position: relative;z-index: 1;overflow: hidden;margin: 0 auto;background: #d3d3d3 url(../images/loading.jpg) repeat-x;}.ggLoading {position: absolute;left: 40%;top: 200px;width: 325px;text-align: center;height: 56px;background-position: 0 -274px;background-repeat: no-repeat;line-height: 56px;color: #9c9c9c;}.ggLoading2 {width: 330px;height: 56px;background-position: 213px -330px;background-repeat: no-repeat;}.ggLoading em {font-weight: bold;}.ggs {width: 200%;height: 500px;left: -50%;top: 0;position: absolute;}.ggBox {width: 1920px;height: 500px;margin: 0 auto;}.ggBox a {display: block;width: 1920px;height: 500px;position: absolute;z-index: 1;opacity: 0.1;}.ggBox img {display: block;width: 1920px;height: 500px;}.ggb {position: absolute;width: 100%;left: 0;bottom: 0;height: 40px;z-index: 4;background-color: #32342e;background-repeat: repeat-x;background-position: 50% -40px;}.ggBtns {width: 960px;height: 40px;margin: 0 auto;border-left: 1px solid #090908;border-right: 1px solid #6a6a60;}.ggBtns a {float: left;display: block;width: 240px;height: 40px;text-align: center;padding-top: 10px;color: #848380;font-size: 14px;line-height: 40px;background-position: 0 10px;position: relative;top: -10px;outline: none;background-repeat: no-repeat;cursor: pointer;}.ggBtns a em {display: block;width: 210px;height: 40px;margin: 0 auto;overflow: hidden;}.ggBtns a:hover {color: #e7e7e7;}.ggBtns a:focus {outline: none;}.ggBtns a.ggOn {color: #e7e7e7;background-position: 0 0;}.ggb, .ggBtns a {background-image: url(../images/main.jpg);}a.ggOn {background-image: url(../images/gg.png);}

JS代码
终于来到重点部分了,这部分的代码不多,一起来看下吧。

$(function () {//文档加载后执行 //定义$con,$box,$btns,$i变量,autoChange自动播放函数,loop定时器。 var $con = $("#gg"), $box = $con.find("#ggBox"), $btns = $con.find("#ggBtns"), i = 0, autoChange = function () {i += 1;//计数器+1if (i === 4) { i = 0; }//如果计数器i等4就把i重置为0. $btns.find("a:eq(" + i + ")").addClass("ggOn").siblings().removeClass("ggOn");//找到TAB按钮中的第i个a标签,为其加上ggOn的样式,同时移除所有同级的a标签ggOn样式var curr = $box.find("a:eq(" + i + ")"), prev = curr.siblings();//定义curr变量,并赋值为$box中当前显示图片的a标签,定义prev变量,赋值为$box中除了当前显示图片的A标签外的所有A标签。prev.css("z-index", 2);//$box中除了当前显示图片的A标签外的所有A标签的index值变为2,即向下移一层curr.css("z-index", 3).animate({ //$box中当前显示图片的a标签index值变为3,即向上移一层,然后使用jquery动画以150毫秒把透明度变为1,之后执行匿名函数function。"opacity": 1}, 150, function () { //$box中除了当前显示图片的A标签外的所有A标签的index值变为1,并把透明度变为0.1prev.css({"z-index": 1, "opacity": 0.1});});}, loop = setInterval(autoChange, 5000);//定义定时器,每5秒执行一次autoChange函数,达到自动播放效果。$con.hover(function () { //定义鼠标悬浮与离开事件clearInterval(loop); //鼠标悬浮时移除Loog定时器,即停止播放}, function () {loop = setInterval(autoChange, 5000); //鼠标离开时载放Loog定时器,继续播放});$btns.find("a").click(function () {//定义tab按钮事件i = $(this).index() - 1; //tab按钮中当前A标签的index值-1,并赋值给i计数器autoChange();//调用切换方法切换图片});});

不知亲们看完以上的注释,知道原理了没有呢?其实整个代码分为四个部分:
1、图片切换
以i作为计数器,显示当前为i的图片,其它图片全部隐藏,给当前为i的按钮加上ggOn样式,其它按钮去除ggOn样式,而每次调用切换函数时i自增1。
2、自动播放
定义一个定时器loop,每5秒调用一次切换函数。
3、鼠标hover事件
原来就是鼠标悬浮时清除loop定时器,鼠标离开时载入loop定时器。
4、按钮事件
绑定tab按钮单击事件,单击后给i赋上当前tab按钮的index值-1,调用切换函数。

以上就是jquery实现图片轮播的全部关键性代码,希望大家仔细研究,教程中仍存在许多不足,希望大家予以改进。