本文實例講述了jQuery實現寬屏圖片輪播實例教程。分享給大家供大家參考。具體如下:
運行效果截圖如下:
引入jquery庫
<script src="http://www.gimoo.net/t/1904/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 title="5月22日測試開啟領報名資格" style="z-index: 3; opacity: 4;"> <img src="http://www.gimoo.net/t/1904/images/1.jpg" alt="" /></a> <a title="首測世界的雕琢篇章開啟"> <img src="http://www.gimoo.net/t/1904/images/2.jpg" alt="" /></a> <a title="上古世紀游戲資料手冊"> <img src="http://www.gimoo.net/t/1904/images/3.jpg" alt="" /></a> <a title="游戲四大特色揭曉"> <img src="http://www.gimoo.net/t/1904/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;//計數器+1 if (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.1 prev.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實現圖片輪播的全部關鍵性代碼,希望大家仔細研究,教程中仍存在許多不足,希望大家予以改進。