欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

javascript 仿QQ滑動菜單效果代碼

 更新時間:2010年09月03日 21:21:06   作者:  
javascript 仿QQ滑動菜單效果代碼,非常漂亮的代碼,學(xué)習(xí)js的朋友可以參考下代碼風(fēng)格。
【程序源碼】
復(fù)制代碼 代碼如下:

var QQ = function() {
// 公用函數(shù)
function T$(id) { return document.getElementById(id); }
function T$$(root, tag) { return (root || document).getElementsByTagName(tag); }
function $extend(des, src) { for(var p in src) { des[p] = src[p]; } return des; }
function $each(arr, callback, thisp) {
if (arr.forEach) {arr.forEach(callback, thisp);}
else { for (var i = 0, len = arr.length; i < len; i++) callback.call(thisp, arr[i], i, arr);}
}
function currentStyle(elem, style) {
return elem.currentStyle || document.defaultView.getComputedStyle(elem, null);
}
// 緩動類
var Tween = {
Quart: {
easeOut: function(t,b,c,d){
return -c * ((t=t/d-1)*t*t*t - 1) + b;
}
},
Back: {
easeOut: function(t,b,c,d,s){
if (s == undefined) s = 1.70158;
return c*((t=t/d-1)*t*((s+1)*t + s) + 1) + b;
}
},
Bounce: {
easeOut: function(t,b,c,d){
if ((t/=d) < (1/2.75)) {
return c*(7.5625*t*t) + b;
} else if (t < (2/2.75)) {
return c*(7.5625*(t-=(1.5/2.75))*t + .75) + b;
} else if (t < (2.5/2.75)) {
return c*(7.5625*(t-=(2.25/2.75))*t + .9375) + b;
} else {
return c*(7.5625*(t-=(2.625/2.75))*t + .984375) + b;
}
}
}
}

// 主類構(gòu)造函數(shù)
var scrollTrans = function(cid, sid, count, config) {
var self = this;
if (!(self instanceof scrollTrans)) {
return new scrollTrans(cid, sid, count, config);
}
self.container = T$(cid);
self.scroller = T$(sid);
if (!(self.container || self.scroller)) {
return;
}
self.config = $extend(defaultConfig, config || {});
self.index = 0;
self.timer = null;
self.count = count;
self.step = self.scroller.offsetWidth / count;
};

// 默認(rèn)配置
var defaultConfig = {
trigger: 1, // 觸發(fā)方式1:click other: mouseover
auto: true, // 是否自動切換
tween: Tween.Quart.easeOut, // 默認(rèn)緩動類
Time: 10, // 滑動延時
duration: 50, // 切換時間
pause: 3000, // 停頓時間
start: function() {}, // 切換開始執(zhí)行函數(shù)
end: function() {} // 切換結(jié)束執(zhí)行函數(shù)
};

scrollTrans.prototype = {
constructor: scrollTrans,
transform: function(index) {
var self = this;
index == undefined && (index = self.index);
index < 0 && (index = self.count - 1) || index >= self.count && (index = 0);
self.time = 0;
self.target = -Math.abs(self.step) * (self.index = index);
self.begin = parseInt(currentStyle(self.scroller)['left']);
self.change = self.target - self.begin;
self.duration = self.config.duration;
self.start();
self.run();
},

run: function() {
var self = this;
clearTimeout(self.timer);
if (self.change && self.time < self.duration) {
self.moveTo(Math.round(self.config.tween(self.time++, self.begin, self.change, self.duration)));
self.timer = setTimeout(function() {self.run()}, self.config.Time);
} else {
self.moveTo(self.target);
self.config.auto && (self.timer = setTimeout(function() {self.next()}, self.config.pause));
}
},

moveTo: function(i) {
this.scroller.style.left = i + 'px';
},

next: function() {
this.transform(++this.index);
}
};

return {
scroll: function(cid, sid, count, config) {
window.onload = function() {
var frag = document.createDocumentFragment(),
nums = [];
for (var i = 0; i < count; i++) {
var li = document.createElement('li');
(nums[i] = frag.appendChild(document.createElement('li'))).innerHTML = i + 1;
}
T$('page').appendChild(frag);

// 調(diào)用主類
var st = scrollTrans(cid, sid, count, config);
$each(nums, function(o, i) {
o[st.config.trigger == 1 ? 'onclick' : 'onmouseover'] = function() { o.className = 'on'; st.transform(i); }
o.onmouseout = function() { o.className = ''; st.transform();}
});
st.start = function() {
$each(nums, function(o, i) {
o.className = st.index == i ? 'on' : '';
});
};
st.transform();
}
}
}
}();

QQ.scroll('container', 'scroller', 5, {trigger: 0});

【參數(shù)說明】

復(fù)制代碼 代碼如下:

var defaultConfig = {
trigger: 1, // 觸發(fā)方式 1:click 其余: mouseover
auto: true, // 是否自動切換
tween: Tween.Quart.easeOut, // 默認(rèn)緩動類
Time: 10, // 滑動延時
duration: 50, // 切換時間
pause: 3000, // 停頓時間
start: function() {}, // 切換開始執(zhí)行函數(shù)
end: function() {} // 切換結(jié)束執(zhí)行函數(shù)
};

【使用方法】

復(fù)制代碼 代碼如下:

QQ.scroll('container' /*外部容器ID*/, 'scroller'/*滑動容器ID*/, 5/*切換圖片數(shù)目*/, {trigger: 0} /*默認(rèn)配置*/);

【源碼下載】
slider

相關(guān)文章

  • js實(shí)現(xiàn)的動畫導(dǎo)航菜單效果代碼

    js實(shí)現(xiàn)的動畫導(dǎo)航菜單效果代碼

    這篇文章主要介紹了js實(shí)現(xiàn)的動畫導(dǎo)航菜單效果代碼,涉及JavaScript通過鼠標(biāo)事件控制頁面元素樣式動態(tài)變換的技巧,具有一定參考借鑒價值,需要的朋友可以參考下
    2015-09-09
  • JS實(shí)現(xiàn)圖片上下切換

    JS實(shí)現(xiàn)圖片上下切換

    這篇文章主要為大家詳細(xì)介紹了JS實(shí)現(xiàn)圖片上下切換,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-07-07
  • 手機(jī)圖片預(yù)覽插件photoswipe.js使用總結(jié)

    手機(jī)圖片預(yù)覽插件photoswipe.js使用總結(jié)

    這篇文章主要為大家詳細(xì)總結(jié)了手機(jī)圖片預(yù)覽插件photoswipe.js使用方法,感興趣的小伙伴們可以參考一下
    2016-08-08
  • js模擬C#中List的簡單實(shí)例

    js模擬C#中List的簡單實(shí)例

    本篇文章主要是對js模擬C#中List的簡單實(shí)例進(jìn)行了介紹,需要的朋友可以過來參考下,希望對大家有所幫助
    2014-03-03
  • 微信小程序之五種頁面跳轉(zhuǎn)方法小結(jié)

    微信小程序之五種頁面跳轉(zhuǎn)方法小結(jié)

    本文主要介紹了微信小程序之五種頁面跳轉(zhuǎn)方法小結(jié),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2022-06-06
  • es6中的解構(gòu)賦值、擴(kuò)展運(yùn)算符和rest參數(shù)使用詳解

    es6中的解構(gòu)賦值、擴(kuò)展運(yùn)算符和rest參數(shù)使用詳解

    這篇文章分別給大家介紹了關(guān)于es6中解構(gòu)賦值、擴(kuò)展運(yùn)算符和rest參數(shù)使用的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧。
    2017-09-09
  • 微信小程序中實(shí)現(xiàn)手指縮放圖片的示例代碼

    微信小程序中實(shí)現(xiàn)手指縮放圖片的示例代碼

    本篇文章主要介紹了微信小程序中實(shí)現(xiàn)手指縮放圖片的示例代碼,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-03-03
  • 解決select2在bootstrap modal中不能正常使用的問題

    解決select2在bootstrap modal中不能正常使用的問題

    今天小編就為大家分享一篇解決select2在bootstrap modal中不能正常使用的問題,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2018-08-08
  • 原生JavaScript制作微博發(fā)布面板效果

    原生JavaScript制作微博發(fā)布面板效果

    這篇文章主要為大家詳細(xì)介紹了原生JavaScript制作微博發(fā)布面板效果,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2016-03-03
  • javascript實(shí)現(xiàn)的固定位置懸浮窗口實(shí)例

    javascript實(shí)現(xiàn)的固定位置懸浮窗口實(shí)例

    這篇文章主要介紹了javascript實(shí)現(xiàn)的固定位置懸浮窗口,以一個完整實(shí)例形式詳細(xì)分析了javascript實(shí)現(xiàn)固定位置懸浮窗口的相關(guān)技巧,非常具有實(shí)用價值,需要的朋友可以參考下
    2015-04-04

最新評論