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

首頁 > 語言 > JavaScript > 正文

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

2024-05-06 16:25:48
字體:
來源:轉載
供稿:網友
這篇文章主要介紹了Jquery1.9.1源碼分析系列(十五)動畫處理之外篇 的相關資料,需要的朋友可以參考下
 

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 );  }}; 

  變量jQuery.timers = [];用來保存每次tick需要執行的函數列表。一般來說就只有一個函數,就是Animation函數中定義的tick函數。jQuery.fx.interval可以用來設置動畫每兩幀之間的時間間隔,默認為13毫秒。

  動畫的分析就到這里。下面把動畫相關的api列一下

jQuery.fn.show([ duration ] [, easing ] [, complete ] | options )(顯示所有匹配的元素。此外,你還可以指定元素顯示的過渡動畫效果。如果元素本身是可見的,則不對其作任何改變。如果元素是隱藏的,則使其可見。與該函數相對的是hide()函數,用于隱藏所有匹配的元素)

jQuery.fn.hide([ duration ] [, easing ] [, complete ] | options)(隱藏所有匹配的元素。此外,你還可以指定元素隱藏的過渡動畫效果。如果元素本身是不可見的,則不對其作任何改變。如果元素是可見的,則將其隱藏。)

jQuery.fn.toggle([ duration ] [, easing ] [, complete ] | options)(切換所有匹配的元素。此外,你還可以指定元素切換的過渡動畫效果。所謂"切換",也就是如果元素當前是可見的,則將其隱藏;如果元素當前是隱藏的,則使其顯示(可見)。)

這里介紹的toggle()函數用于切換元素的顯示/隱藏。jQuery還有一個同名的事件函數toggle(),用于綁定click事件并在觸發時輪流切換執行不同的事件處理函數。

jQuery.fn.slideDown([ duration ] [, easing ] [, complete ] | options)(顯示所有匹配的元素,并帶有向下滑動的過渡動畫效果。向下滑動的動畫效果,即元素可見區域的高度從0逐漸增大到其原有高度(向下逐漸展開)。如果元素本身是可見的,則不對其作任何改變。如果元素是隱藏的,則使其可見。

與該函數相對的是slideUp()函數,用于隱藏所有匹配的元素,并帶有向上滑動的過渡動畫效果)

jQuery.fn.slideUp([ duration ] [, easing ] [, complete ] | options)(隱藏所有匹配的元素,并帶有向上滑動的過渡動畫效果。向上滑動的動畫效果,即元素可見區域的高度從原有高度逐漸減小到0(向上逐漸收起)。如果元素本身是隱藏的,則不對其作任何改變。如果元素是可見的,則將其隱藏)

jQuery.fn.slideToggle([ duration ] [, easing ] [, complete ] | options)(切換所有匹配的元素,并帶有滑動的過渡動畫效果。所謂"切換",也就是如果元素當前是可見的,則將其隱藏(向上滑動);如果元素當前是隱藏的,則使其顯示(向下滑動))

jQuery.fn.fadeIn([ duration ] [, easing ] [, complete ] | options)(顯示所有匹配的元素,并帶有淡入的過渡動畫效果。淡入的動畫效果,即元素的不透明度的比例從0%逐漸增加到100%。如果元素本身是可見的,則不對其作任何改變。如果元素是隱藏的,則使其可見。與該函數相對的是fadeOut()函數,用于隱藏所有匹配的元素,并帶有淡出的過渡動畫效果)

jQuery.fn.fadeOut([ duration ] [, easing ] [, complete ] | options)(隱藏所有匹配的元素,并帶有淡出的過渡動畫效果。所謂"淡出"的動畫效果,即元素的不透明度的比例從100%逐漸減小到0%。如果元素本身是隱藏的,則不對其作任何改變。如果元素是可見的,則將其隱藏)

jQuery.fn.fadeToggle([ duration ] [, easing ] [, complete ] | options)(切換所有匹配的元素,并帶有淡入/淡出的過渡動畫效果。所謂"切換",即如果元素當前是可見的,則將其隱藏(淡出);如果元素當前是隱藏的,則使其顯示(淡入))

jQuery.fn.animate(cssProperties [, duration ] [, easing ] [, complete ] | cssProperties, options)(執行一個基于css屬性的自定義動畫。你可以為匹配的元素設置css樣式,animate()函數將會執行一個從當前樣式到指定的css樣式的一個過渡動畫。例如:某個div元素的當前高度為100px,將其CSS height屬性設為200px,animate()將會執行一個將div元素的高度從100px逐漸增加到200px的過渡動畫)

jQuery.fn.delay(duration [, queueName ])(延遲隊列中下一項的執行。delay()可以將隊列中等待執行的下一個動畫延遲指定的時間后才執行。它常用在隊列中的兩個jQuery效果函數之間,從而在上一個動畫效果執行后延遲下一個動畫效果的執行時間。如果下一項不是效果動畫,則它不會被加入效果隊列中,因此該函數不會對它進行延遲調用)

jQuery.fn.stop([ queueName ] [, clearQueue [, jumpToEnd ] ])(停止當前匹配元素上正在運行的動畫。默認情況下,stop()函數只會停止當前正在運行的動畫。如果你使用animate()函數為當前元素設置了A、B、C這3段動畫,如果當前正在執行的動畫是A,則只會停止動畫A的執行,不會阻止動畫B和C的執行。當然,你也可以通過指定可選的選項參數來停止所有的動畫。停止動畫并不是恢復到該動畫執行前的狀況,而是直接停止,當前動畫執行到什么狀態,就停留在什么狀態。例如:執行一個元素高度從100px到200px的過渡動畫,當高度為150px時停止了該動畫,則當前高度仍然保持150px的現狀。如果該動畫設置了執行完畢后的回調函數,則不會執行該回調函數。)

jQuery.fn.finish([ queueName ])(立即完成隊列中的所有動畫。finish()會停止當前正在運行的動畫,刪除所有隊列中的動畫,并完成匹配元素的所有動畫)

jQuery.fn. fadeTo([speed,]opacity[,callback])(將被選元素的不透明度逐漸地改變為指定的值)

jQuery.fx.off(該屬性用于設置或返回是否全局性地禁用所有動畫。如果不對該屬性設置值,則返回表示是否全局性地禁用了動畫效果的布爾值。如果將該屬性設為true,將全局性地禁用所有動畫。所有正在執行的動畫隊列不會受到影響。尚未執行的任何動畫隊列都會在執行時立即完成,而不再帶有動畫效果。如果將該屬性設為false,將全局性地啟用動畫效果。

你可以在遇到以下情況時,需要禁用動畫效果:你在配置比較低的電腦上使用jQuery;某些用戶可能由于動畫效果而遇到了可訪問性問題。)

jQuery.fx.interval(該屬性用于設置或返回動畫的幀速(毫秒值)。jQuery.fx.interval屬性用于設置jQuery動畫每隔多少毫秒繪制一幀圖像(觸發一次樣式更改,瀏覽器可能會重新繪制當前頁面)。該值越小,則動畫的觸發次數越多,動畫效果也更明顯、更平滑,當然也就越耗費性能。更改該屬性值時,正在執行的動畫隊列將不受影響。尚未執行的任何動畫隊列都將按照更改后的幀速來繪制動畫效果)

以上內容是腳本之家小編給大家介紹的Jquery1.9.1源碼分析系列(十五)動畫處理之外篇 ,jQuery 1.9.1源碼分析系列(十五)之動畫處理,點擊了解詳情。



注:相關教程知識閱讀請移步到JavaScript/Ajax教程頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表

圖片精選

亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
国产丝袜精品视频| 97av在线视频免费播放| 久久亚洲精品一区| 高清欧美性猛交| 亚洲精品久久7777777| 欧美激情免费观看| 国产精自产拍久久久久久蜜| 久久伊人色综合| 国产精品久久久一区| 亚洲综合在线播放| 日韩av手机在线| 久久精品福利视频| 欧美电影免费观看网站| 亚洲日本欧美日韩高观看| 庆余年2免费日韩剧观看大牛| 成人h视频在线观看播放| 久久精品久久久久久国产 免费| 久久久伊人日本| 亚洲一区二区三区xxx视频| 美女撒尿一区二区三区| 亚洲xxxx18| 亚洲欧美日韩中文在线制服| 91a在线视频| 在线观看日韩www视频免费| 欧美大片免费观看在线观看网站推荐| 久久av中文字幕| 国产va免费精品高清在线| 国产视频欧美视频| 色先锋久久影院av| 91亚洲精品在线| 亚洲天堂网在线观看| 国产亚洲欧美另类中文| 亚洲精品在线观看www| 另类天堂视频在线观看| 日韩av影视在线| 久久久亚洲国产天美传媒修理工| 欧美成人精品激情在线观看| 日韩欧美在线视频日韩欧美在线视频| 国产成人精品视频在线| 亚洲男人的天堂在线播放| 国产成人啪精品视频免费网| 欧美一级片免费在线| 亚洲精品电影久久久| 日韩欧美一区视频| 久久天天躁日日躁| 成人黄色免费片| 91在线免费视频| 亚洲国产精品久久久久秋霞蜜臀| 26uuu国产精品视频| 国产午夜精品麻豆| 欧美激情精品在线| 成人欧美在线视频| 最近2019中文字幕在线高清| 久久久之久亚州精品露出| 日韩成人激情影院| 亚洲福利视频免费观看| 色www亚洲国产张柏芝| 欧美日韩一区二区精品| 国产精品一区二区三| 久久久国产精品一区| **欧美日韩vr在线| 日韩精品www| 久久韩剧网电视剧| 法国裸体一区二区| 亚洲风情亚aⅴ在线发布| 国产成人久久久精品一区| 日韩av在线一区二区| 国产男人精品视频| 欧美激情区在线播放| 日本a级片电影一区二区| 久久天堂电影网| 国产欧美va欧美va香蕉在线| 亚洲a在线观看| 日韩在线视频中文字幕| 亚洲国产97在线精品一区| 在线播放亚洲激情| 午夜精品理论片| 欧美激情国产日韩精品一区18| 欧美精品一本久久男人的天堂| 91精品国产91久久久久久| 国产一区二区三区直播精品电影| 亚洲一区二区少妇| 国产日韩在线观看av| 国产欧美一区二区三区在线看| 国产成人综合精品| 亚洲新声在线观看| 亚洲一区二区免费| 中文字幕视频在线免费欧美日韩综合在线看| 精品亚洲va在线va天堂资源站| 亚洲男女自偷自拍图片另类| 欧美怡红院视频一区二区三区| 国产精品www网站| 国产日韩换脸av一区在线观看| 国内精品视频久久| 亚洲精品美女在线观看播放| 欧美精品少妇videofree| 国产精品成人久久久久| 国产精品久久久久国产a级| 欧美性猛交xxxx富婆弯腰| 精品视频久久久| 日韩成人av一区| 亚洲成色777777女色窝| 国产精品久久久久久久久久久久| 最新69国产成人精品视频免费| 在线观看免费高清视频97| 91久久精品日日躁夜夜躁国产| 欧美性色视频在线| 欧美日韩国产区| 日本精品久久久久影院| 久久久久久久久久久国产| 欧美夫妻性生活视频| 日本精品久久电影| 亚洲黄色有码视频| 91老司机在线| 日韩美女免费线视频| 日韩精品久久久久| 国产精品久久久久久久久久ktv| 中文字幕亚洲一区二区三区| 欧美性受xxxx白人性爽| 日韩av在线免播放器| 日韩在线免费视频| 日韩视频免费看| 欧美日韩国产在线| 国产人妖伪娘一区91| 亚洲福利视频二区| 亚洲一区第一页| 亚洲xxxx3d| 69av视频在线播放| 精品呦交小u女在线| 性欧美暴力猛交69hd| 在线视频欧美性高潮| 亚洲一区二区久久久| 国产精品视频内| 最近2019中文字幕mv免费看| www.日韩欧美| 青青草精品毛片| 国产一区av在线| 欧美视频中文在线看| 久久天天躁狠狠躁夜夜躁| 精品成人乱色一区二区| 亚洲欧美日韩久久久久久| 日韩的一区二区| 国产亚洲欧洲高清一区| 亚洲伊人久久综合| 精品欧美一区二区三区| 国产v综合ⅴ日韩v欧美大片| 在线看片第一页欧美| 久久免费高清视频| 亚洲国产精品资源| 日本欧美精品在线| 成人免费淫片aa视频免费| 日本精品视频在线观看| www.精品av.com| 欧美激情亚洲综合一区| 精品一区二区电影| 国产aaa精品| 欧美国产日韩中文字幕在线| 欧美电影《睫毛膏》| 九九视频这里只有精品| 国产精品成av人在线视午夜片| 国产精品网址在线| 国产精品男人的天堂| 在线播放精品一区二区三区| 亚洲成人网av|