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

javascript簡易緩動插件(源碼打包)

 更新時間:2012年02月16日 19:46:13   作者:  
最近,同事在做一個項目的時候,有個需求,需要一款動畫庫來支持
要求如下:
可以開始、暫停(線性、非線性tween都支持)、繼續(xù)、結(jié)束
支持多個樣式并行
最好不依賴于某個框架下運行
文件尺寸越小越好
他找了一下現(xiàn)有的一些插件或者庫,鮮有能滿足或者比較均衡的,我在這個要求下,寫了一個比較簡陋的動畫組件,基本滿足了這個需求。先上代碼
在線演示:http://demo.jb51.net/js/2012/animate/
打包下載:animate_jquery.rar
html部分:
復(fù)制代碼 代碼如下:

<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8" />
<title>animate</title>
<script type="text/javascript" src="tangram-1.5.0.core.js"></script>
<script type="text/javascript" src="jquery.min.js"></script>
<style>
html,body,ul,li{padding:0;margin:0;}
#anim{width:50px;height:50px;background:red;position:absolute; top:30px;left:0;}
</style>
</head>
<body>
<div>
<input type="button" value="start" onclick="an.start()" />
<input type="button" value="pause" onclick="an.pause()" />
<input type="button" value="resume" onclick="an.resume()" />
<input type="button" value="stop" onclick="an.stop()" />
<a target="_self" id="demolink" href="animate.html?demo=1" />auto start,pasue,then resume</a>
</div>
<div id="anim"></div>
</body></html>

animate部分:
復(fù)制代碼 代碼如下:

function animate(options){
this.from = options.from;//如果沒有from,就計算出from
this.to = options.to || {};
this.onStart = options.onStart || empty;//以下是一些回調(diào)函數(shù),就不采用事件機制了
this.onStop = options.onStop || empty;
this.onAnimate = options.onAnimate || empty;
this.onContinue = options.onContinue || empty;
this.onPause = options.onPause || empty;
var element = options.element;
var duration = options.duration || 300;//變化的總時長,單位是ms
var pending = false;//是不是已經(jīng)暫停了,如果還木有開始的話,該值也是true
var timer = null;
var mixin = options.mix;
var defaultState = this.from || getState(element, this.to);//原始的數(shù)據(jù)
var thiz = this;
//獲取最初始的樣式
function getState(ele, targetStyles){
var obj = {};
var i = 0;
for (var p in targetStyles)
{
i++;
obj[p] = parseFloat(mixin.getStyle(ele, p));
}
if(i == 0){
return null;
}
return obj;
}
function empty(){}
function animate(from, to, elapse){
var startTime = (new Date).getTime() + (elapse ? - elapse : 0);//如果有第三個參數(shù),證明是從一個暫停開始的,那么就設(shè)置startTime為當前時間減去暫定時已經(jīng)逝去的時間,如果只有兩個參數(shù),那么逝去時間就是0
timer = setInterval(function(){
var endTime = (new Date).getTime();
if(endTime - startTime < duration){
thiz.onAnimate();
currentElapse = endTime - startTime;
for(var p in from){
if(from.hasOwnProperty(p)){
var currentPropertyStyle = mixin.compute(currentElapse, from[p], to[p]-from[p], duration);
mixin.setStyle(element, p, currentPropertyStyle);
}
}
}
else{
thiz.stop(thiz.to);
}
}, 16);
}
this.start = function(){
if(pending){
this.resume();
}
else{
this.onStart();
animate(defaultState, this.to);
}
}
this.stop = function(){
clearInterval(timer);
var styles = this.to;
for(var p in styles){
if(styles.hasOwnProperty(p)){
mixin.setStyle(element, p, styles[p]);
}
}
this.onStop();
}
this.pause = function(){
clearInterval(timer);
pending = true;
this.onPause();
}
this.resume = function(){
pending = false;
this.onContinue();
animate(defaultState, this.to, currentElapse);
}
}

使用部分:
復(fù)制代碼 代碼如下:

var mixinT = {
getStyle:baidu.dom.getStyle,
setStyle:baidu.dom.setStyle,
compute:function(t, b, c, d){
//return t*c/d + b;
if (t==0) return b;
if (t==d) return b+c;
if ((t/=d/2) < 1) return c/2 * Math.pow(2, 10 * (t - 1)) + b;
return c/2 * (-Math.pow(2, -10 * --t) + 2) + b;
}
};
var mixinJQ = {
getStyle:function(ele, styleName){
return $(ele).css(styleName);
},
setStyle:function(ele, styleName, styleValue){
$(ele).css(styleName, styleValue);
},
compute:function(t, b, c, d){
return b+ t*c/d;
}
};
var an = new animate({
element:document.getElementById('anim'),
//from:{'width':100, 'height':100, left:0, top:30},
to:{left:500},
mix:mixinT,
duration:2000
});
if(/demo=1/.test(location.search)){
var demolink = baidu.g('demolink');
demolink.href= 'animate.html';
demolink.innerHTML = 'back';
an.start();
setTimeout(function(){
an.pause();
resume();
}, 1200);
function resume(){
setTimeout(function(){an.resume()}, 1000);
}
}

上面是一個完整demo的代碼。做幾點說明:
代碼尺寸足夠小了,一共才100行,gzip后連1k都不到。
滿足了可以start、pause、resume、stop的需求,贈送了幾個回調(diào)函數(shù):D。
可以支持多個樣式一起變化。
采用了一個mixin變量,傳進來三個函數(shù)需要在執(zhí)行動畫時的操作,getStyle、setStyle、compute,我感覺這三個確實和用戶的選擇有關(guān)系,前兩個可能和框架有關(guān),第三個和用戶采用的變化計算方式有關(guān),之所以傳進去四個參數(shù),主要是和主流的tween類能適應(yīng)起來,可以參考http://www.robertpenner.com/easing/和http://www.actionscript.org/resources/articles/170/1/Flash-MX-2004-Undocumented-TweenEasing-Classes-Documented/Page1.html。我給的例子用了tangram和jquery倆類庫,分別對應(yīng)了兩個mixin對象,做一下簡單的適配,就能用了。
一些“私有”變量和函數(shù)放閉包里了,這樣初始化一個animate的時候,對象是干凈的,但是缺點就是占用內(nèi)存多了,每個實例都維護自己的方法。
使用的時候,可以不提供options.from,函數(shù)會根據(jù)額options.to來計算from中對應(yīng)樣式的值,這很大程度上依賴于mixin提供的方法夠不夠強大,所以這一塊還是有bug 的,不過,80%的功能夠用了。麻雀雖小,五臟俱全了。

相關(guān)文章

  • JavaScript循環(huán)遍歷小結(jié)

    JavaScript循環(huán)遍歷小結(jié)

    本文給大家總結(jié)了javascript中的循環(huán)遍歷,給大家總結(jié)的非常全面,感興趣的朋友跟隨小編一起看看吧
    2018-09-09
  • 前端面試知識點錦集(JavaScript篇)

    前端面試知識點錦集(JavaScript篇)

    這篇文章主要為大家分享了前端面試知識點錦集JavaScript篇,細致的給出了每個js面試知識點的答案,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2016-12-12
  • javascript打開新窗口同時關(guān)閉舊窗口

    javascript打開新窗口同時關(guān)閉舊窗口

    因業(yè)務(wù)需要,在網(wǎng)上查找這個問題的解決辦法,但是昏天黑地地搞了半天,找到的方法雖然可以實現(xiàn)功能,但是總是會跳出討厭的“關(guān)閉窗口”的提示框,郁悶。
    2009-01-01
  • TypeScript?接口繼承的具體使用

    TypeScript?接口繼承的具體使用

    本文主要介紹了TypeScript?接口繼承的具體使用,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2022-07-07
  • 微信小程序開發(fā)實現(xiàn)的選項卡(窗口頂部/底部TabBar)頁面切換功能圖文詳解

    微信小程序開發(fā)實現(xiàn)的選項卡(窗口頂部/底部TabBar)頁面切換功能圖文詳解

    這篇文章主要介紹了微信小程序開發(fā)實現(xiàn)的選項卡(窗口頂部/底部TabBar)頁面切換功能,結(jié)合圖文與實例形式詳細分析了微信小程序選項卡切換相關(guān)操作實現(xiàn)技巧,需要的朋友可以參考下
    2019-05-05
  • JS實現(xiàn)頁面滾動到關(guān)閉時的位置與不滾動效果

    JS實現(xiàn)頁面滾動到關(guān)閉時的位置與不滾動效果

    這篇文章主要介紹了JS實現(xiàn)頁面滾動到關(guān)閉時的位置與不滾動效果,滾動有兩種方案,其一,利用路由中的meta,在離開頁面時緩存 top 信息,其二,利用keep-alive緩存整個頁面。但是僅限于沒有實時數(shù)據(jù)變動的頁面,需要的朋友可以參考下本文
    2022-06-06
  • JavaScript十大取整方法實例教程

    JavaScript十大取整方法實例教程

    這篇文章主要給大家介紹了關(guān)于JavaScript的十大取整方法,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-12-12
  • IE8提示Invalid procedure call or argument 異常的解決方法

    IE8提示Invalid procedure call or argument 異常的解決方法

    某臺機器上,訪問公司的好幾個產(chǎn)品網(wǎng)站,都拋出很多 Invalid procedure call or argument ,跟進了下,情況最后簡化為
    2012-09-09
  • 詳解微信小程序調(diào)用支付接口支付

    詳解微信小程序調(diào)用支付接口支付

    這篇文章主要介紹了微信小程序調(diào)用支付接口支付,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-04-04
  • JS+CSS實現(xiàn)網(wǎng)頁加載中的動畫效果

    JS+CSS實現(xiàn)網(wǎng)頁加載中的動畫效果

    這篇文章主要為大家詳細介紹了JS+CSS實現(xiàn)網(wǎng)頁加載中的動畫效果,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-10-10

最新評論