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

javascript動畫對象支持加速、減速、緩入、緩出的實現(xiàn)代碼

 更新時間:2012年09月30日 21:01:29   作者:  
javascript動畫對象支持加速、減速、緩入、緩出的實現(xiàn)代碼,需要的朋友可以參考下
調(diào)用接口:
復制代碼 代碼如下:

/**
* @param elem {HTMLElement} 執(zhí)行動畫的HTML元素
* @param params {JSON} 動畫執(zhí)行過過程中需要修改的HTML屬性
* @param duration {Number} 可選,動畫執(zhí)行時間,單位毫秒
* @param easing {String} 可選,動畫執(zhí)行的方式,緩入easeIn、緩出easeOut
* @param callback {Function} 可選,動畫執(zhí)行完成時的回調(diào)函數(shù)
* @return
*/
effect.animate(elem, params, duration, easing, callback);

使用它用不了20行代碼就可以做一個產(chǎn)品圖片減速淡出、加速淡入的切換效果點擊這里查看演示效果
復制代碼 代碼如下:

//輔助對象,讀/寫DOM元素屬性
var attribute = {
get: function(elem, attr){
var val;
if(elem.currentStyle){
if(attr === "opacity") {
val = elem.filters.alpha[attr];
}else {
val = elem.currentStyle[attr];
}
}
else{
val = getComputedStyle(elem)[attr];
if(attr === "opacity") {
val = 100 * val;
}
}
return val;
},
set: function(elem, attr, val){
if(attr=='opacity'){
elem.style.filter = 'alpha(opacity='+ (val) +')';
elem.style.opacity = (val)/100;
}
else{
elem.style[attr] = val + 'px';
}
}
};
/*
* 描述: tween動畫算法。
* @param Number t: 動畫已經(jīng)執(zhí)行的時間(實際上時執(zhí)行多少次/幀數(shù))
* @param Number b: 起始位置
* @param Number c: 終止位置
* @param Number d: 從起始位置到終止位置的經(jīng)過時間(實際上時執(zhí)行多少次/幀數(shù))
*/
var tween = {
//緩入
easeIn: function (t, b, c, d){
return c * (t/=d) * t + b;
},
//緩出
easeOut: function (t,b,c,d){
return -c * (t/=d) * (t-2) + b;
}
};
//動畫對象
var effect = {
animate: function(elem, params, duration, easing, callback){
var dt = new Date().getTime(),
b = 0,
c = 0,
d = duration || 500,
fps = 1000/60;
var changes = [];
for(var attr in params){
b = parseFloat(attribute.get(elem, attr));
c = params[attr] - b;
changes.push({
attr: attr,
b: b,
c: c
});
}
easing = easing || "easeOut";
callback = callback || new Function;
setTimeout(function(){
var t = new Date().getTime() - dt;
var b, c, attr;
for(var i=0; i<changes.length; i++){
b = changes[i].b;
c = changes[i].c;
attr = changes[i].attr;
attribute.set(elem, attr, tween[easing](t, b, c, d));
if(d <= t){
attribute.set(elem, attr, params[attr]);
callback();
return;
}
}
setTimeout(arguments.callee, fps);
}, fps);
}
};
//by rentj1@163.com

相關文章

  • JavaScript 浮點數(shù)運算 精度問題

    JavaScript 浮點數(shù)運算 精度問題

    JavaScript小數(shù)在做四則運算時,精度會丟失,這會在項目中引起諸多不便,先請看下面腳本。
    2009-10-10
  • 深入淺析ES6 Class 中的 super 關鍵字

    深入淺析ES6 Class 中的 super 關鍵字

    本文給大家收藏整理了ES6 Class 中的 super 關鍵字,非常不錯,具有參考借鑒價值,需要的朋友參考下吧
    2017-10-10
  • JS中6個對象數(shù)組去重的方法

    JS中6個對象數(shù)組去重的方法

    這篇文章主要給大家介紹了關于JS中6個對象數(shù)組去重的方法,javascript數(shù)組去重是一個比較常見的需求,解決方法也有很多種,文中每種解決方法都給出了示例代碼,需要的朋友可以參考下
    2023-07-07
  • ionic實現(xiàn)可滑動的tab選項卡切換效果

    ionic實現(xiàn)可滑動的tab選項卡切換效果

    這篇文章主要為大家詳細介紹了ionic實現(xiàn)可滑動的tab選項卡切換效果,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2016-08-08
  • BootStrap表單寬度設置方法

    BootStrap表單寬度設置方法

    這篇文章主要介紹了BootStrap表單寬度設置方法,僅僅是小編日常遇到問題記錄,寫的不好還請見諒,需要的朋友可以參考下
    2017-03-03
  • 使用百度地圖api實現(xiàn)根據(jù)地址查詢經(jīng)緯度

    使用百度地圖api實現(xiàn)根據(jù)地址查詢經(jīng)緯度

    這篇文章主要介紹了使用百度地圖api實現(xiàn)根據(jù)地址查詢經(jīng)緯度的方法,附上實例,推薦給有需要的小伙伴們。
    2014-12-12
  • JavaScript給事件委托批量添加事件監(jiān)聽詳細流程

    JavaScript給事件委托批量添加事件監(jiān)聽詳細流程

    事件委托,一般來講,會把一個或者一組元素的事件委托到它的父層或者更外層元素上,真正綁定事件的是外層元素,當事件響應到需要綁定的元素上時,會通過事件冒泡機制從而觸發(fā)它的外層元素的綁定事件上,然后在外層元素上去執(zhí)行函數(shù)
    2021-10-10
  • javascript-hashchange事件和歷史狀態(tài)管理實例分析

    javascript-hashchange事件和歷史狀態(tài)管理實例分析

    這篇文章主要介紹了javascript-hashchange事件和歷史狀態(tài)管理,結合實例形式分析了javascript-hashchange基本功能、原理及歷史狀態(tài)管理相關操作技巧,需要的朋友可以參考下
    2020-04-04
  • JavaScript隨機數(shù)的組合問題案例分析

    JavaScript隨機數(shù)的組合問題案例分析

    這篇文章主要介紹了JavaScript隨機數(shù)的組合問題,結合具體案例形式分析了JavaScript隨機數(shù)的組合問題相關算法原理、實現(xiàn)技巧與注意事項,需要的朋友可以參考下
    2020-05-05
  • JavaScript實現(xiàn)移動小精靈的案例代碼

    JavaScript實現(xiàn)移動小精靈的案例代碼

    這篇文章主要介紹了JavaScript實現(xiàn)移動小精靈的案例代碼,本文分步驟給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2020-12-12

最新評論