Js動(dòng)畫(huà)(四) ---獲取樣式


先上效果圖:

animation.gif

實(shí)際上摧扇,就是改變一個(gè)div寬度的效果

初步實(shí)現(xiàn)過(guò)程:

a. 簡(jiǎn)單地定義一個(gè)div

<body>
<div id="div1"></div>
</body>

b. 定義div的樣式:

 <style>
        #div1 {
            width: 200px;
            height: 200px;
            background: #ff0;
            border: 2px solid #000;
        }
</style>

c. 實(shí)現(xiàn)js動(dòng)畫(huà):

 <script>
        window.onload = function () {
            startMove();
        };
        
        function startMove() {
            /**
             * 定義一個(gè)時(shí)間函數(shù)每30ms減少一次div的寬度
             */
            setInterval(function () {
                //獲取到div對(duì)象
                var oDiv = document.getElementById("div1");
                //減少div的寬度
                //注意這里要先用parseInt方法獲取到數(shù)值,然后才可以進(jìn)行減法運(yùn)算蟹演,最后記得加上單位
                oDiv.style.width = parseInt(oDiv.style.width) - 2 + 'px';
            }, 30);
        }
    </script>

這樣我們的初步設(shè)計(jì)就完成机久,點(diǎn)擊運(yùn)行,結(jié)果發(fā)現(xiàn)藏鹊,div的寬度并不會(huì)改變H蠹ァ!盘寡!

因?yàn)槲覀兪褂胦bj.style.width方法只能獲取到行內(nèi)樣式楚殿,不能獲取到非行內(nèi)樣式!

因此竿痰,我們修改如下:實(shí)際上就是增加了樣內(nèi)樣式

<body>
<div id="div1" style="width: 200px"></div>
</body>

但這樣的話脆粥,我們就無(wú)法將html與css分離,這明顯不是一個(gè)很好的辦法影涉。
實(shí)際上变隔,獲取非行內(nèi)樣式,我們可以采用另一個(gè)方法--- currentStyle(針對(duì)IE)和getComputedStyle(針對(duì)火狐和谷歌)

修改如下:

 setInterval(function () {
                //獲取到div對(duì)象
                var oDiv = document.getElementById("div1");
                //減少div的寬度
                //注意這里要先用parseInt方法獲取到數(shù)值蟹倾,然后才可以進(jìn)行減法運(yùn)算匣缘,最后記得加上單位
                oDiv.style.width = parseInt(window.getComputedStyle(oDiv, null)['width']) - 2 + 'px';
            }, 30);

但以上只是針對(duì)谷歌或狐火,但并不支持IE鲜棠,因此肌厨,我們需要進(jìn)一步修改。

        /**
         * 封裝一個(gè)函數(shù)用來(lái)獲取樣式
         * @param obj 傳入的元素對(duì)象
         * @param attr 傳入要獲取的樣式
         * @returns {*}
         */
        function getStyle(obj, attr) {
            //判斷是否支持currentStyle屬性豁陆,若為IE則支持
            if (obj.currentStyle){
                //返回該樣式
                return obj.currentStyle[attr];
            } 
            //若不支持柑爸,則使用getComputedStyle方法,使得火狐和谷歌支持
            else {
                return getComputedStyle(obj, null)[attr];
            }
        }

調(diào)用方法如下:

//這里調(diào)用getStyle函數(shù)去獲取到樣式
oDiv.style.width = parseInt(getStyle(oDiv, 'width')) - 2 + 'px';
完整代碼如下:
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Get Style</title>
    <style>
        #div1 {
            width: 200px;
            height: 200px;
            background: #ff0;
            border: 2px solid #000;
        }
    </style>
    <script>
        window.onload = function () {
            startMove();
        };

        function startMove() {
            /**
             * 定義一個(gè)時(shí)間函數(shù)每30ms減少一次div的寬度
             */
            setInterval(function () {
                //獲取到div對(duì)象
                var oDiv = document.getElementById("div1");
                //減少div的寬度
                //這里調(diào)用getStyle函數(shù)去獲取到樣式
                oDiv.style.width = parseInt(getStyle(oDiv, 'width')) - 2 + 'px';
            }, 30);
        }
        /**
         * 封裝一個(gè)函數(shù)用來(lái)獲取樣式
         * @param obj 傳入的元素對(duì)象
         * @param attr 傳入要獲取的樣式
         * @returns {*}
         */
        function getStyle(obj, attr) {
            //判斷是否支持currentStyle屬性盒音,若為IE則支持
            if (obj.currentStyle){
                //返回該樣式
                return obj.currentStyle[attr];
            }
            //若不支持表鳍,則使用getComputedStyle方法,使得火狐和谷歌支持
            else {
                return getComputedStyle(obj, null)[attr];
            }
        }
    </script>

</head>
<body>
<div id="div1"></div>
</body>
</html>
總結(jié):

JS中 obj.style.attr 只能獲取行內(nèi)樣式
要獲取非行內(nèi)樣式要通過(guò)obj.currentStyle[attr]或者getComputedStyle(obj,false)[attr]方法獲取
其中obj.currentStyle[attr]只支持IE瀏覽器祥诽,getComputedStyle(obj,false)[attr]支持火狐和谷歌瀏覽器譬圣。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市原押,隨后出現(xiàn)的幾起案子胁镐,更是在濱河造成了極大的恐慌,老刑警劉巖,帶你破解...
    沈念sama閱讀 218,036評(píng)論 6 506
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件盯漂,死亡現(xiàn)場(chǎng)離奇詭異颇玷,居然都是意外死亡,警方通過(guò)查閱死者的電腦和手機(jī)就缆,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,046評(píng)論 3 395
  • 文/潘曉璐 我一進(jìn)店門(mén)帖渠,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái),“玉大人竭宰,你說(shuō)我怎么就攤上這事空郊。” “怎么了切揭?”我有些...
    開(kāi)封第一講書(shū)人閱讀 164,411評(píng)論 0 354
  • 文/不壞的土叔 我叫張陵狞甚,是天一觀的道長(zhǎng)。 經(jīng)常有香客問(wèn)我廓旬,道長(zhǎng)哼审,這世上最難降的妖魔是什么? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 58,622評(píng)論 1 293
  • 正文 為了忘掉前任孕豹,我火速辦了婚禮涩盾,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘励背。我一直安慰自己春霍,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,661評(píng)論 6 392
  • 文/花漫 我一把揭開(kāi)白布叶眉。 她就那樣靜靜地躺著址儒,像睡著了一般。 火紅的嫁衣襯著肌膚如雪衅疙。 梳的紋絲不亂的頭發(fā)上离福,一...
    開(kāi)封第一講書(shū)人閱讀 51,521評(píng)論 1 304
  • 那天,我揣著相機(jī)與錄音炼蛤,去河邊找鬼。 笑死蝶涩,一個(gè)胖子當(dāng)著我的面吹牛理朋,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播绿聘,決...
    沈念sama閱讀 40,288評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼嗽上,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來(lái)了熄攘?” 一聲冷哼從身側(cè)響起兽愤,我...
    開(kāi)封第一講書(shū)人閱讀 39,200評(píng)論 0 276
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎,沒(méi)想到半個(gè)月后浅萧,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體逐沙,經(jīng)...
    沈念sama閱讀 45,644評(píng)論 1 314
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,837評(píng)論 3 336
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片皆警。...
    茶點(diǎn)故事閱讀 39,953評(píng)論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡萌壳,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出端朵,到底是詐尸還是另有隱情,我是刑警寧澤,帶...
    沈念sama閱讀 35,673評(píng)論 5 346
  • 正文 年R本政府宣布残揉,位于F島的核電站,受9級(jí)特大地震影響芋浮,放射性物質(zhì)發(fā)生泄漏抱环。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,281評(píng)論 3 329
  • 文/蒙蒙 一途样、第九天 我趴在偏房一處隱蔽的房頂上張望江醇。 院中可真熱鬧,春花似錦何暇、人聲如沸陶夜。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 31,889評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)条辟。三九已至,卻和暖如春宏胯,著一層夾襖步出監(jiān)牢的瞬間羽嫡,已是汗流浹背。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 33,011評(píng)論 1 269
  • 我被黑心中介騙來(lái)泰國(guó)打工肩袍, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留杭棵,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 48,119評(píng)論 3 370
  • 正文 我出身青樓氛赐,卻偏偏與公主長(zhǎng)得像魂爪,于是被迫代替她去往敵國(guó)和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子艰管,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,901評(píng)論 2 355

推薦閱讀更多精彩內(nèi)容

  • 在前端開(kāi)發(fā)過(guò)程中往往需要?jiǎng)討B(tài)的編輯滓侍、修改一個(gè)UI的樣式,這必然涉及到style的獲取與設(shè)置牲芋。一般都說(shuō)有圖有真相撩笆,而...
  • HTML+CSS 1.對(duì)WEB標(biāo)準(zhǔn)以及W3C的理解與認(rèn)識(shí) 標(biāo)簽閉合捺球、標(biāo)簽小寫(xiě)、不亂嵌套夕冲、提高搜索機(jī)器人搜索幾率氮兵、使...
    aymincoder閱讀 5,061評(píng)論 2 189
  • 本章轉(zhuǎn)載自新浪博客網(wǎng)友:blog.sina.com.cn/s/blog_7f5571aa0102w2tv.html...
    czboy閱讀 1,458評(píng)論 0 11
  • w一:rem布局公式 document.documentElement.style.fontSize=20*doc...
    stars甜閱讀 783評(píng)論 0 1
  • JavaScript 將字符串轉(zhuǎn)換為數(shù)字 parseInt() ◆只保留數(shù)字的整數(shù)部分,不會(huì)進(jìn)行四舍五入運(yùn)算耘擂。 ...
    AkaTBS閱讀 985評(píng)論 0 9