封裝了一個JS方法,支持元素的基本動畫:寬、高、透明度...等,也支持鏈式動畫和同時運動。chrome
獲取元素的屬性的函數並進行了兼容性處理:瀏覽器
1 function getStyle(obj, attr) { 2 if(obj.currentStyle){ //IE瀏覽器 3 return obj.currentStyle[attr]; 4 }else{ //chrome、firefox等瀏覽器 5 return getComputedStyle(obj,null)[attr]; 6 } 7 }
動畫函數:函數
1 var timer = null; // 聲明一個timer來存儲定時器 2 function animate(obj, Obj, callback) { 3 clearInterval(obj.timer); 4 obj.timer = setInterval(function() { 5 /* 6 * 當咱們改變多個屬性時,若是其中一個屬性已經達到目標值,就會清除定時器,就會致使其餘沒有達到目標值的屬性也會中止 7 * 爲了解決這個問題,咱們聲明一個節流閥flag,讓它爲true 8 * 判斷是否還有沒達到目標值的屬性,若是還有,就讓flag爲false(關閉節流閥),讓定時器繼續執行 9 * 當全部屬性都達到了目標值時,才執行清除定時器那一步 10 */ 11 var flag = true; 12 for(var attr in Obj) { // for...in...遍歷對象 13 var icur = 0; // 存儲獲取過來的屬性值 14 if(attr == 'opacity') { // 判斷獲取過來的屬性是否爲opacity 15 icur = Math.round(parseFloat(getStyle(obj, attr)) * 100); // float會有小偏差,因此須要四捨五入一下 16 } else { 17 icur = parseInt(getStyle(obj, attr)); // 獲取過來的值可能帶單位,因此須要用到parseInt() 18 } 19 var speed = (Obj[attr] - icur) / 10; // 速度 逐漸變慢(也能夠設爲固定值實現勻速運動) 20 speed = speed > 0 ? Math.ceil(speed) : Math.floor(speed); // speed並不老是整數,會致使和目標值不相等,因此須要對speed進行取整,大於0向上取整,小於0向下取整 21 if(icur != Obj[attr]) { // 判斷是否還有屬性沒有達到目標值 22 flag = false; 23 } 24 if(attr == 'opacity') { // opacity是沒有單位的,因此在這裏須要判斷一下 25 obj.style.filter = 'alpha(opacity = '+ (icur + speed) +')'; 26 obj.style.opacity = (icur + speed) / 100; // opacity別忘了除以100 27 } else { 28 obj.style[attr] = icur + speed + 'px'; // 原來的值加上速度賦值給屬性 29 } 30 } 31 if(flag) { // 當全部屬性都達到目標值,即flag爲true時,再中止定時器 32 clearInterval(obj.timer); 33 callback && callback(); // 判斷是否有回調函數,有的話就執行 34 } 35 }, 25) 36 }
接下來咱們來調用一下:動畫
1 var box = document.querySelector('.box'); 2 box.addEventListener("mouseover", function() { 3 animate(this, {width: 300, height: 200, opacity: 100}, function() { 4 animate(box, {width: 200, height: 100, opacity: 30}); 5 }); 6 });
結果以下:this