亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

js修改元素樣式的九種方式總結(jié)

 更新時間:2024年04月29日 11:16:12   作者:冰糖雪梨dd  
用慣了vue和react之后可能會慢慢淡忘掉原生的一些操作dom的幾種方式,有的時候確實(shí)需要我們通過原生的方式進(jìn)行操作,下面這篇文章主要給大家介紹了關(guān)于js修改元素樣式的九種方式,需要的朋友可以參考下

1.直接設(shè)置style的屬性

style屬性可以設(shè)置或返回元素的內(nèi)聯(lián)樣式,對于更改同一個元素的同一種樣式,設(shè)置style屬性的優(yōu)先級較高

  • 語法:element.style.property = value
  • property為CSS屬性名,如:color,margin。如果屬性名原來包含“-”,則需轉(zhuǎn)換為小駝峰形式,如:backgroundColor,marginLeft。
var box = document.querySelector('div')
box.style.color = "#fff" // 將元素中文字設(shè)置為白色 
box.style.marginLeft = "100px" // 將元素左外邊距設(shè)置為100px 

某些情況用這個設(shè)置 !important值無效

如果屬性有’-'號,就寫成駝峰的形式(如textAlign) 如果想保留 - 號,就中括號的形式

element.style.height = '100px';

2.直接設(shè)置屬性

只能用于某些屬性,相關(guān)樣式會自動識別

element.setAttribute('height', 100);
element.setAttribute('height', '100px');

3.設(shè)置style的屬性

element.setAttribute('style', 'height: 100px !important');

4.使用setProperty

  • 如果要設(shè)置!important,推薦用這種方法設(shè)置第三個參數(shù)
element.style.setProperty('height', '300px', 'important');

5.改變class (推薦)

  • 通過改變偽元素父級的class來動態(tài)更改偽元素的樣式
element.className = 'blue';
element.className += 'blue fb';

6.設(shè)置cssText

element.style.cssText = 'height: 100px !important';
element.style.cssText += 'height: 100px !important';

7.引入css樣式文件

  • 創(chuàng)建引入新的css樣式文件
 function addNewStyle(newStyle) {
            var styleElement = document.getElementById('styles_js');
<span class="token keyword">if</span> <span class="token punctuation">(</span><span class="token operator">!</span>styleElement<span class="token punctuation">)</span> <span class="token punctuation">{<!-- --></span> styleElement <span class="token operator">&#61;</span> document<span class="token punctuation">.</span><span class="token function">createElement</span><span class="token punctuation">(</span><span class="token string">&#39;style&#39;</span><span class="token punctuation">)</span><span class="token punctuation">;</span> styleElement<span class="token punctuation">.</span>type <span class="token operator">&#61;</span> <span class="token string">&#39;text/css&#39;</span><span class="token punctuation">;</span> styleElement<span class="token punctuation">.</span>id <span class="token operator">&#61;</span> <span class="token string">&#39;styles_js&#39;</span><span class="token punctuation">;</span> document<span class="token punctuation">.</span><span class="token function">getElementsByTagName</span><span class="token punctuation">(</span><span class="token string">&#39;head&#39;</span><span class="token punctuation">)</span><span class="token punctuation">[</span><span class="token number">0</span><span class="token punctuation">]</span><span class="token punctuation">.</span><span class="token function">appendChild</span><span class="token punctuation">(</span>styleElement<span class="token punctuation">)</span><span class="token punctuation">;</span> <span class="token punctuation">}</span> styleElement<span class="token punctuation">.</span><span class="token function">appendChild</span><span class="token punctuation">(</span>document<span class="token punctuation">.</span><span class="token function">createTextNode</span><span class="token punctuation">(</span>newStyle<span class="token punctuation">)</span><span class="token punctuation">)</span><span class="token punctuation">;</span> <span class="token punctuation">}</span> <span class="token function">addNewStyle</span><span class="token punctuation">(</span><span class="token string">&#39;.box {height: 100px !important;}&#39;</span><span class="token punctuation">)</span><span class="token punctuation">;</span> 

8.使用addRule、insertRule

// 在原有樣式操作
        document.styleSheets[0].addRule('.box', 'height: 100px');
        document.styleSheets[0].insertRule('.box {height: 100px}', 0);
<span class="token comment">// 或者插入新樣式時操作</span> <span class="token keyword">var</span> styleEl <span class="token operator">&#61;</span> document<span class="token punctuation">.</span><span class="token function">createElement</span><span class="token punctuation">(</span><span class="token string">&#39;style&#39;</span><span class="token punctuation">)</span><span class="token punctuation">,</span> styleSheet <span class="token operator">&#61;</span> styleEl<span class="token punctuation">.</span>sheet<span class="token punctuation">;</span> styleSheet<span class="token punctuation">.</span><span class="token function">addRule</span><span class="token punctuation">(</span><span class="token string">&#39;.box&#39;</span><span class="token punctuation">,</span> <span class="token string">&#39;height: 100px&#39;</span><span class="token punctuation">)</span><span class="token punctuation">;</span> styleSheet<span class="token punctuation">.</span><span class="token function">insertRule</span><span class="token punctuation">(</span><span class="token string">&#39;.box {height: 100px}&#39;</span><span class="token punctuation">,</span> <span class="token number">0</span><span class="token punctuation">)</span><span class="token punctuation">;</span> document<span class="token punctuation">.</span>head<span class="token punctuation">.</span><span class="token function">appendChild</span><span class="token punctuation">(</span>styleEl<span class="token punctuation">)</span><span class="token punctuation">;</span> 

9.通過classList控制樣式

  • classList屬性返回一個元素類屬性集合(這里可以簡單理解為類名的集合),通過使用classList中的方法可以方便的訪問和控制元素類名,達(dá)到控制樣式的目的

classList常用方法介紹:

名稱描述
add(class1, class2, …)添加一個或多個類名
remove(class1, class2, …)移除一個或多個類名
replace(oldClass, newClass)替換類名
contains(class)判定類名是否存在,返回布爾值
toggle(class, true|false)如果類名存在,則移除它,否則添加它,第二個參數(shù)代表無論類名是否存在,強(qiáng)制添加(true)或刪除(false
<div class="box">classList test</div>
<script>
  var box = document.querySelector('.box')
  box.classList.add('box1', 'box2')    // [box] => [box, box1, box2]
  box.classList.remove('box1', 'box2') // [box, box1, box2] => [box]
  box.classList.replace('box', 'box2')  // [box] => [box2]
  box.classList.contains('box1')  // 當(dāng)前元素不包含類名box1,返回false
  box.classList.toggle('active')   // [box2] => [box2, active]
</script>

總結(jié) 

到此這篇關(guān)于js修改元素樣式的九種方式的文章就介紹到這了,更多相關(guān)js修改元素樣式內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • 通過實(shí)例解析JavaScript for in及for of區(qū)別

    通過實(shí)例解析JavaScript for in及for of區(qū)別

    這篇文章主要介紹了通過實(shí)例解析JavaScript for in及for of區(qū)別,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下
    2020-06-06
  • Javascript頁面添加到收藏夾的簡單方法

    Javascript頁面添加到收藏夾的簡單方法

    這篇文章介紹了Javascript頁面添加到收藏夾的簡單方法,有需要的朋友可以參考一下
    2013-08-08
  • javascript 匿名函數(shù)的理解(透徹版)

    javascript 匿名函數(shù)的理解(透徹版)

    網(wǎng)上很多解釋,我無法理解,我想知道原理。。。這篇文章應(yīng)該可以透徹一點(diǎn)
    2010-01-01
  • Electron 使用 Nodemon 配置自動重啟的方法

    Electron 使用 Nodemon 配置自動重啟的方法

    在Electron開發(fā)過程中,每次代碼修改后需手動重新啟動應(yīng)用,這一過程可以通過引入Nodemon工具自動化,Nodemon能夠監(jiān)測文件變化并自動重啟服務(wù)器,本文給大家介紹Electron 使用 Nodemon 配置自動重啟,感興趣的朋友一起看看吧
    2024-09-09
  • 微信小程序?qū)崿F(xiàn)輪播圖(適配機(jī)型)

    微信小程序?qū)崿F(xiàn)輪播圖(適配機(jī)型)

    這篇文章主要為大家詳細(xì)介紹了微信小程序?qū)崿F(xiàn)輪播圖,適配機(jī)型,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-06-06
  • 使用canvas進(jìn)行圖像編輯的實(shí)例

    使用canvas進(jìn)行圖像編輯的實(shí)例

    下面小編就為大家?guī)硪黄褂胏anvas進(jìn)行圖像編輯的實(shí)例。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-08-08
  • javascript 播放器 控制

    javascript 播放器 控制

    javascript 播放器 控制...
    2007-01-01
  • JavaScript中的變量提升和函數(shù)提升

    JavaScript中的變量提升和函數(shù)提升

    這篇文章主要介紹了JavaScript中的變量提升和函數(shù)提升,在js中對變量進(jìn)行操作后打印值經(jīng)常會出現(xiàn)undefined的現(xiàn)象。其實(shí)原因是因?yàn)閖s中有一個叫做變量提升的功能
    2022-07-07
  • JavaScript顯示當(dāng)前文檔最后修改日期的方法

    JavaScript顯示當(dāng)前文檔最后修改日期的方法

    這篇文章主要介紹了JavaScript顯示當(dāng)前文檔最后修改日期的方法,實(shí)例分析了javascript中document.lastModified的使用技巧,非常具有實(shí)用價值,需要的朋友可以參考下
    2015-03-03
  • Javascript 籬式條件判斷

    Javascript 籬式條件判斷

    我們已經(jīng)知道,null 沒有任何的屬性值,并且無法獲取其實(shí)體(existence)值。所以 null.property 返回的是錯誤(error)而不是 undefined 。
    2008-08-08

最新評論