亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 擴展 > jQuery > 正文

Jquery1.9.1源碼分析系列(十五)動畫處理之外篇

2024-09-06 20:04:43
字體:
來源:轉載
供稿:網友

a.動畫兼容Tween.propHooks

  Tween.propHooks提供特殊情況下設置、獲取css特征值的方法,結構如下

Tween.propHooks = {  _default: {    get: function(){...},    set: function(){...}  },  scrollTop: {    set: function(){...}  }  scrollLeft: {    set: function(){...}  }} 

  Tween.propHooks.scrollTop 和Tween.propHooks.scrollLeft兩個主要是在ie8離線狀態下會出現混亂而把css特征值保存到節點上

set: function( tween ) {  if ( tween.elem.nodeType && tween.elem.parentNode ) {    tween.elem[ tween.prop ] = tween.now;  }} 

  Tween.propHooks._default的get方法會嘗試直接從節點上取得css的tween.prop特征值,如果取不到則使用jQuery.css()方式來獲取。該方法處理中,簡單的值如“10px”會被解析為浮點數;復雜的值,如“旋轉(1rad)”返回原樣。并對返回結果再做處理:空字符串, null, undefined 和 "auto"都轉化為0;其他情況不變。

get: function( tween ) {  var result;  if ( tween.elem[ tween.prop ] != null &&    (!tween.elem.style || tween.elem.style[ tween.prop ] == null) ) {    return tween.elem[ tween.prop ];  }  //傳遞一個空字符串作為第三個參數的.css會自動嘗試parseFloat,  //并返回到一個字符串,如果解析失敗的話。  //所以,簡單的值,如“10px”會被被解析為浮點數。復雜的值,如“旋轉(1rad)”返回原樣。  result = jQuery.css( tween.elem, tween.prop, "" );  // 空字符串, null, undefined 和 "auto"都轉化為0  return !result || result === "auto" ? 0 : result;} 

  Tween.propHooks._default的set方法先會嘗試jQuery.fx.step[ tween.prop ]來設置向下兼容;否則會使用jQuery.style來設置css特征值;最極端情況則會將特征值直接保存在節點上

set: function( tween ) {  //使用step hook向下兼容 - 使用cssHook如果他存在 - 使用.style如果可用的話  //使用直接的特征值如果可用可用的話  if ( jQuery.fx.step[ tween.prop ] ) {    jQuery.fx.step[ tween.prop ]( tween );  } else if ( tween.elem.style && ( tween.elem.style[ jQuery.cssProps[ tween.prop ] ] != null || jQuery.cssHooks[ tween.prop ] ) ) {    jQuery.style( tween.elem, tween.prop, tween.now + tween.unit );  } else {    tween.elem[ tween.prop ] = tween.now;  }} 

b. 動畫專用對象jQuery.fx

  jQuery.fx封裝了一些用來執行動畫動作的函數,結構如下

jQuery.fx = {  tick = function () {...},//每個時間點都會執行的函數外殼,會取出jQuery.timers中的函數執行  timer = function ( timer ) {...},//執行參數中的函數并啟動計時  interval = 13, //計時步長  start = function () {...},//啟動計時  stop = function () {...},//停止計時  speeds = {slow: 600,fast: 200,_default: 400},//動畫速度(完整動畫執行時間)  step = {}//向下兼容<1.8擴展點} 

  詳細的源碼分析如下

jQuery.fx = Tween.prototype.init;//每個時間點都會執行的函數外殼,會取出jQuery.timers中的函數執行jQuery.fx.tick = function() {  var timer,  timers = jQuery.timers,  i = 0;  fxNow = jQuery.now();  for ( ; i < timers.length; i++ ) {    timer = timers[ i ];    // Checks the timer has not already been removed    if ( !timer() && timers[ i ] === timer ) {      timers.splice( i--, 1 );    }  }  if ( !timers.length ) {    jQuery.fx.stop();  }  fxNow = undefined;};//執行參數中的函數并啟動計時jQuery.fx.timer = function( timer ) {  if ( timer() && jQuery.timers.push( timer ) ) {    jQuery.fx.start();  }};//計時步長jQuery.fx.interval = 13;//啟動計時jQuery.fx.start = function() {  if ( !timerId ) {    timerId = setInterval( jQuery.fx.tick, jQuery.fx.interval );  }};//停止計時jQuery.fx.stop = function() {  clearInterval( timerId );  timerId = null;};//動畫速度(完整動畫執行時間)jQuery.fx.speeds = {  slow: 600,  fast: 200,  // Default speed  _default: 400};//向下兼容<1.8擴展點jQuery.fx.step = {};   這里其中執行動畫的關鍵源碼是//動畫入口函數function Animation( elem, properties, options ){  ...  jQuery.fx.timer(    jQuery.extend( tick, {      elem: elem,      anim: animation,      queue: animation.opts.queue    })  );  ...}//執行參數中的函數并啟動計時jQuery.fx.timer = function( timer ) {  if ( timer() && jQuery.timers.push( timer ) ) {    jQuery.fx.start();  }};//計時步長jQuery.fx.interval = 13;//啟動計時jQuery.fx.start = function() {  if ( !timerId ) {    timerId = setInterval( jQuery.fx.tick, jQuery.fx.interval );  }}; 
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
日韩欧美在线国产| 国产成人鲁鲁免费视频a| 日韩成人在线电影网| 成人福利在线视频| 国产偷亚洲偷欧美偷精品| 精品中文字幕视频| 国产精品入口福利| 久久精品2019中文字幕| 日本亚洲欧洲色| 国产日本欧美一区二区三区在线| 欧美剧在线观看| 精品视频在线观看日韩| 日韩性生活视频| 国产剧情久久久久久| 国产精品视频午夜| 播播国产欧美激情| 亚洲欧美日韩天堂一区二区| 国产精品小说在线| 亚洲一区二区三区毛片| 成人信息集中地欧美| 91精品国产网站| 精品亚洲国产成av人片传媒| 亚洲精品一区在线观看香蕉| 国模视频一区二区三区| 狠狠色狠狠色综合日日五| 日韩在线观看视频免费| 一区二区三区动漫| 91精品在线影院| 日韩精品在线免费观看视频| 欧美日韩成人在线观看| 久久久久久久久91| 日韩av中文字幕在线免费观看| 91精品国产成人| 日韩成人激情视频| 亚洲天堂免费观看| 亚洲www永久成人夜色| 欧美日本啪啪无遮挡网站| 91网站在线免费观看| 91免费视频国产| 国产精品久久久久久久久久久不卡| 日韩欧美中文字幕在线播放| 精品呦交小u女在线| 国产午夜精品免费一区二区三区| 2025国产精品视频| 成人免费视频a| 日韩欧美国产免费播放| 久久免费福利视频| 日韩亚洲一区二区| 日本人成精品视频在线| 精品国内自产拍在线观看| 亚洲欧美自拍一区| 午夜免费日韩视频| 91国产美女在线观看| 久久免费少妇高潮久久精品99| 国产精品久久久久99| 亚洲美女久久久| 日本一区二区在线免费播放| 亚洲免费视频在线观看| 欧美国产视频一区二区| 欧美日韩美女视频| 日韩欧美aaa| 国产精品一区专区欧美日韩| 77777亚洲午夜久久多人| 欧美日韩在线另类| 欧美精品在线网站| 国产精品一区=区| 国模精品一区二区三区色天香| 中文字幕精品影院| 欧美情侣性视频| 欧美午夜精品久久久久久久| 亚洲性日韩精品一区二区| 色妞色视频一区二区三区四区| 亚洲一区美女视频在线观看免费| 成人国产在线视频| 国产精品一区二区久久精品| 国产精品成av人在线视午夜片| 久久精品美女视频网站| 久久99国产综合精品女同| 草民午夜欧美限制a级福利片| 欧美一区二区三区免费视| 亚洲乱码国产乱码精品精天堂| 国产欧美精品日韩精品| 亚洲国产精品久久| 欧美精品一区在线播放| 亚洲人成自拍网站| 国内精品久久久久影院优| 91探花福利精品国产自产在线| 另类视频在线观看| 欧美日韩亚洲91| 成人国产精品久久久久久亚洲| 国产精品一区二区性色av| 91精品国产91| 亚洲欧美日韩第一区| 亚洲精品国产品国语在线| 精品久久久一区二区| 欧美激情啊啊啊| 亚洲女成人图区| 久久九九亚洲综合| 日韩中文字幕精品视频| 懂色av影视一区二区三区| 亚洲天堂一区二区三区| 一本色道久久88精品综合| 国产亚洲激情在线| 成人a在线观看| 国产午夜精品美女视频明星a级| 隔壁老王国产在线精品| 欧美一区第一页| 亚洲国产欧美一区| 亚洲电影免费观看高清| 8050国产精品久久久久久| 欧美精品videosex性欧美| 国产欧美最新羞羞视频在线观看| 亚洲一区二区三区香蕉| 日韩激情在线视频| 国产精品丝袜一区二区三区| 国产精品视频1区| 中文字幕久久亚洲| 国产精欧美一区二区三区| 日韩精品中文在线观看| 91九色视频导航| 国产在线观看精品| 亚洲一区中文字幕| 国产精品扒开腿做爽爽爽男男| 国产精品扒开腿爽爽爽视频| 国产精品27p| 在线电影中文日韩| 亚洲国产精品va在线看黑人动漫| 久久av在线播放| 日韩毛片在线看| 中文字幕亚洲欧美日韩在线不卡| 久久精品国产亚洲7777| 亚洲免费高清视频| 亚洲一区二区少妇| 亚洲va电影大全| 97在线看免费观看视频在线观看| 国产美女久久久| 国产欧美一区二区三区视频| 日韩动漫免费观看电视剧高清| 国产午夜精品全部视频播放| 精品久久久久久久久久久久| 久久在线视频在线| 欧美精品一区三区| 久青草国产97香蕉在线视频| 日韩av一区在线观看| 91网站免费观看| 欧美激情va永久在线播放| 激情久久av一区av二区av三区| 欧美激情a∨在线视频播放| 成人免费看吃奶视频网站| 成人欧美一区二区三区黑人| 欧美一区三区三区高中清蜜桃| 国产精品极品尤物在线观看| 欧美激情在线狂野欧美精品| 国产+人+亚洲| 国产精品久久久一区| 欧美视频精品一区| 欧美成人激情视频| 91精品国产乱码久久久久久久久| 韩国国内大量揄拍精品视频| 久久久久久久久久亚洲| 中文字幕在线看视频国产欧美在线看完整| 在线电影欧美日韩一区二区私密| 日本欧美一级片| 啊v视频在线一区二区三区|