html結構:css
<div class="slibanner" >
<div class="slideContent" id="box">
<ul class="slideShow" id="tklist">
<li><a class="slideBlock current" target="_blank" href="#" ><img alt="" data-src="http://img01.cunan.com//upload/test1458716507.jpg"></a></li>
<li><a class="slideBlock current" target="_blank" href="#" ><img alt="" data-src="http://img01.cunan.com//upload/test1458628829.jpg" ></a></li>
<li><a class="slideBlock current" target="_blank" href="#" ><img alt="" data-src="http://img01.cunan.com//upload/test1458118629.jpg" ></a></li>
<li><a class="slideBlock current" target="_blank" href="#" ><img alt="" data-src="http://img01.cunan.com//upload/test1458206514.jpg" ></a></li>
<li><a class="slideBlock current" target="_blank" href="#" ><img alt="" data-src="http://img01.cunan.com//upload/test1458189221.jpg" ></a></li>
</ul>
<div class="slideBg"><ul class="slideControl"></ul></div>
</div>
</div>html
css樣式:jquery
/*輪播廣告*/
.slibanner {overflow: hidden;position: relative;width:100%;height: 456px;}
.slideContent { width: 1200px; margin: 0 auto; position: relative; height: 456px; }
.slideContent .slideShow {zoom: 1;width: 1920px; position: absolute; left: -360px; top: 0; height: 456px; }
.slideContent .slideShow li { position: absolute;width: 1920px; height: 456px;}
.slideContent .slideShow .slideBlock {position: absolute;left: 0; opacity: 0;top: 0;}
.slideContent .slideShow .slideBlock.current {opacity: 1;}
.slideContent .slideShow li img {display: block; width:1920px;}web
.slideBg {width: 1200px; height: 1px; position: absolute;z-index: 400; bottom: 38px;}
.slideContent .slideControl li {width:14px; height:14px; margin:0px 5px;background:#999 ;border:1px solid #999; border-radius:100%; cursor: pointer; display: inline-block;overflow: hidden;}
.slideContent .slideControl li.current { border:1px solid #8F1D78;background:none;}
.slideContent .slideControl { /*background:rgba(0,0,0,0.2);*/ height: 1px; border-radius:20px; text-align: center;} 瀏覽器
js代碼:ide
// JavaScript Document
$(function() {
if(document.getElementById("box") != null){
addNumberLi('box','slideShow','li','slideControl',"li","current");
var toggle = new ezg_toggleInterval('box','slideShow','li','slideControl','li','current',500,5000);
}
});
// 各類瀏覽器兼容 頁面是否可見
var hidden, state, visibilityChange;
if (typeof document.hidden !== "undefined") {
hidden = "hidden";
visibilityChange = "visibilitychange";
state = "visibilityState";
} else if (typeof document.mozHidden !== "undefined") {
hidden = "mozHidden";
visibilityChange = "mozvisibilitychange";
state = "mozVisibilityState";
} else if (typeof document.msHidden !== "undefined") {
hidden = "msHidden";
visibilityChange = "msvisibilitychange";
state = "msVisibilityState";
} else if (typeof document.webkitHidden !== "undefined") {
hidden = "webkitHidden";
visibilityChange = "webkitvisibilitychange";
state = "webkitVisibilityState";
}
//添加數字選項
function addNumberLi(boxId,imgUlC,imgLi,numberUlC,numElement,numCurrentName){
//輪換圖片數量
var count = getByClass(document.getElementById(boxId),imgUlC)[0].getElementsByTagName(imgLi).length;
//加載第一個圖片
if(count > 0){
var data_src = $("#" + boxId + " " + imgLi + ":eq(0)").find("img").attr("data-src");
if( typeof data_src !== "undefined" && data_src !== ""){
$("#" + boxId + " " + imgLi + ":eq(0)").find("img").attr("src",data_src);
$("#" + boxId + " " + imgLi + ":eq(0)").find("img").removeAttr("data-src");
};
}
//單個圖片狀況下
if(count < 2){getByClass(document.getElementById(boxId),numberUlC)[0].parentElement.style.display = "none"; return;}
var strNumberLi = "";
for(var i = 0;i < count;i++){
if(i != 0){
strNumberLi += "<"+numElement+"></"+numElement+">";
}else{
strNumberLi += "<"+numElement+" class ='" + numCurrentName + "'></"+numElement+">";
}
}
getByClass(document.getElementById(boxId),numberUlC)[0].innerHTML = strNumberLi;
}動畫
//淡入淡出切換圖片類
function ezg_toggleInterval(boxId,imgUlC,imgLi,numberUlC,numberLi,numberLiNowName,hoverTime,toggleTime){
//邊框盒子
this.oBox = document.getElementById(boxId);
//輪換圖片盒子
this.oBigUl = getByClass(this.oBox,imgUlC)[0];
//輪換圖片項
this.aLiBig = this.oBigUl.getElementsByTagName(imgLi);
//數字選卡盒子
this.oNumUl = getByClass(this.oBox,numberUlC)[0];
//數字選卡項
this.aLiNumber = this.oNumUl.getElementsByTagName(numberLi);
//數字選卡選中類名
this.aLiNumberNowName = numberLiNowName;
//停留觸發
this.aLiNumberOnTab = null;
//定時輪換觸發
this.oBoxInterval = null;
//樣式z-index的值
this.nowZindex = 1;
//當前顯示位置
this.now = 0;
//舊位置
this.old = -1;
//定時對象
this.oBoxTimeout = null;
if(typeof ezg_toggleInterval.tab === "undefined" ){
//切換圖片和相應其餘切換
ezg_toggleInterval.prototype.tab = function(){
this.aLiBig[this.now]
//數字選卡類名更改
for(var i=0; i < this.aLiNumber.length; i++){
if(this.aLiNumber[i].className === ""){continue;}
this.aLiNumber[i].className = '';
}
this.aLiNumber[this.now].className = this.aLiNumberNowName;
//輪換圖片樣式修改
if(this.old > -1){this.aLiBig[this.old].style.opacity = 0;}//防止切換過快和瀏覽器未激活時間縮短問題
var old = 0;
for(var i = 0; i < this.aLiBig.length; i++){
if(this.aLiBig[i].style.zIndex == 1 ){
this.aLiBig[i].style.zIndex = 0;
old = i;
this.old = i;
}
}
this.aLiBig[this.now].style.zIndex = 1;
this.aLiBig[this.now].style.opacity = 0;
//漸變
startMoveJQ(this.aLiBig[this.now],this.aLiBig[old],'opacity',hoverTime*2);
}
//上一個
ezg_toggleInterval.prototype.prev = function(){
//if(!document.hasFocus()) return; //頁面是否激活
if( document[state] !== null && document[state] === 'hidden') return; //頁面是否可見
this.now--;
if(this.now == -1){
this.now = this.aLiNumber.length - 1;
}
this.tab();
}
//下一個
ezg_toggleInterval.prototype.next = function(){
//if(!document.hasFocus()) return; //頁面是否激活
if( document[state] !== null && document[state] === 'hidden') return; //頁面是否可見
this.now++;
if(this.now == this.aLiNumber.length){
this.now = 0;
}
this.tab();
}
//定時輪換
ezg_toggleInterval.prototype.oBoxTimeoutF = function(toggleTime){
var self = this;
if(self.oBoxTimeout){clearTimeout(self.oBoxTimeout);}//防止切換過快和瀏覽器未激活時間縮短問題
self.oBoxTimeout = setTimeout(function(){
self.next();
self.oBoxTimeoutF(toggleTime);
},toggleTime);
}
}
(function(e){
var self = e;
//單個圖片狀況下
if(self.aLiBig.length < 2){return;}
//初始化圖片換項
for(var i = 0; i < self.aLiBig.length; i++){
if(i != 0 ){
self.aLiBig[i].style.zIndex = 0;
self.aLiBig[i].style.opacity = 0;
}else{
self.aLiBig[i].style.zIndex = 1;
self.aLiBig[i].style.opacity = 1;
}
}
//給數字選卡添加事件
for(var i = 0; i < self.aLiNumber.length; i++){
self.aLiNumber[i].index = i;
//鼠標移上事件
self.aLiNumber[i].onmouseover = function(){
var index = this.index;
if(index == self.now){return;}
if(self.aLiNumberOnTab){clearTimeout(self.aLiNumberOnTab);}//防止切換過快和瀏覽器未激活時間縮短問題
//停留多少時間觸發
self.aLiNumberOnTab = setTimeout(function(){
self.now = index;//設置當前位置
self.tab();//切換圖片
},hoverTime*1.2);
}
//鼠標移出事件
self.aLiNumber[i].onmouseout = function(){
clearTimeout(self.aLiNumberOnTab);
}
}
//定時觸發事件
self.oBoxTimeoutF(toggleTime);
self.oBox.onmouseover = function(){
if(self.oBoxTimeout){clearTimeout(self.oBoxTimeout);}
}
self.oBox.onmouseout = function(){
self.oBoxTimeoutF(toggleTime);//改變速度修改3000 ,例如3000=3秒鐘
}
})(this);
}
//根據類名獲得獲得元素 oParent=父對象, name = 類名
function getByClass(oParent,name)
{
if(typeof oParent === "undefined" || oParent == null){return;}
//父元素下的全部元素
var aClass = oParent.getElementsByTagName('*');
//保存name匹配元素
var arlt = [];
for(var i=0; i<aClass.length; i++){
if(aClass[i].className==name){
arlt.push(aClass[i]);
}
}
return arlt;
}
//獲得費行間樣式 obj=本對象,name=樣式名
function getStyle(obj,name)
{
if(obj.currentStyle){
return obj.currentStyle[name];
}else{
return getComputedStyle(obj,false)[name];//火狐瀏覽器狀況
}
}
//jquery animate漸變
function startMoveJQ(obj,objOld,styleName,time){
//延遲加載
var data_src = $(obj).find("img").attr("data-src");
if( typeof data_src !== "undefined" && data_src !== ""){ $(obj).find("img").attr("src",data_src); $(obj).find("img").removeAttr("data-src"); };
//動畫
$(obj).stop().animate({ opacity: 1 },time,function(){
objOld.style.opacity = 0;
});
}this