97免费在线观看视频 I 午夜夫妻视频 I 久久久久久网站 I 天堂网男人 I 欧美大波大乳人奶 I 丝袜 中出 制服 人妻 美腿 I 窝窝午夜理论片影院 I 日韩在线伦理电影 I 韩国特级毛片 I 亚洲欧美另类激情 I 在线成人日韩 I 麻豆视频免费看 I 黄色生活毛片 I 极品一线天小嫩嫩真紧 I 色久天堂 I 久久久久久黄色片 I 林智妍三级露全乳电影视频 I 大肉大捧一进一出好爽视频 I 空乘伦理hd I 少妇口述与子做过爱 I 成人免费影片 I 国产精品国内免费一区二区三区 I 日韩制服一区 I 青青草福利在线 I 日本在线观看不卡视频 I 婷婷六月综合亚洲 I 国产又粗又黄又硬 I 美女扒开屁股让男子桶爽 I 欧美性午夜视频观看 I 欧美狠狠插 I 亚洲福利在线观看视频 I 无码抽搐高潮喷水流白浆 I 亚洲欧美国产日韩色伦 I 你懂的视频网站在线观看 I www.蜜桃视频在线观看 I 日本无码人妻精品一区二区蜜桃 I 久久中文字幕人妻丝袜 I 碰草在线视频 I 日韩精品成人av网站

原生JS讀寫CSS樣式的方法

2020/11/25 17:55:43   閱讀:4518    發布者:4518

  • 通過Element對象的getAttribute()、setAttribute()、removeAttribute()直接讀寫style屬性

        如:elm.setAttribute('style','color:red;line-height:30px');


  • 利用document.styleSheets屬性,返回當前頁面的所有StyleSheet對象(即所有樣式表),它是一個只讀的類數組對象,它的元素是CSSStyleSheet對象(繼承自StyleSheet對象),該對象的屬性方法如下:
        屬性:
                1.cssRules類數組對象,元素是樣式表中CSS規則CSSStyleRule對象;IE9以下為rules;
                2.disabled屬性用于打開或關閉一張樣式表,值為true或disabled;
                3.ownerNode屬性返回StyleSheet對象所在的DOM節點,通常是<link>或<style>。對于那些由其他樣式表引用的樣式表,該屬性為null;
                4.因為CSS的@import命令允許在樣式表中加載其他樣式表,就有了parentStyleSheet屬性,它返回包括了當前樣式表的那張樣式表。如果當前樣式表是頂層樣式表,則該屬性返回null;
                5.type屬性返回StyleSheet對象的type值,通常是text/css;
                6.title屬性返回StyleSheet對象的title值;
                7.href屬性是只讀屬性,返回StyleSheet對象連接的樣式表地址。對于內嵌的style節點,該屬性等于null;
                8.media屬性表示這個樣式表是用于屏幕(screen),還是用于打印(print),或兩者都適用(all),該屬性只讀,默認值是screen;
        方法:deleteRule()從樣式表中刪除一條規則,insertRule()向樣式表中插入一條新規則,IE9以下為addRule()、removeRule();
           如: document.styleSheets[0].insertRule('#test:hover{color: white;}',0);
document.styleSheets[0].deleteRule(0); //刪除樣式表中的第一條規則
document.styleSheets[0].cssRules[1].selectorText; //返回選擇器字符串
document.styleSheets[0].cssRules[1].cssText; //返回規則字符串,含選擇器
document.styleSheets[0].cssRules[1].style.border;
document.styleSheets[0].cssRules[1].style.cssText; //返回當前規則的所有樣式聲明字符串


  • 可以通過DOM節點對象的style對象(即CSSStyleDeclaration對象)來讀寫文檔元素的CSS樣式
             如:var elm = document.getElementById('test');  elm.style.color = 'black';



  • 直接添加樣式表
        1.創建標簽<style>添加一張內置樣式表
            var style1 = document.createElement('style');
            style1.innerHTML = 'body{color:red}#top:hover{background-color: red;color: white;}';
            document.head.appendChild(style1);
        2.另一種是添加外部樣式表,即在文檔中添加一個link節點,然后將href屬性指向外部樣式表的URL
            var link1 = document.createElement('link');
            link1.setAttribute('rel', 'stylesheet');
            link1.setAttribute('type', 'text/css');
            link1.setAttribute('href', 'reset-min.css');
            document.head.appendChild(link1);


  • 用window對象的getComputedStyle方法,第一個參數是Element對象,第二個參數可以是null、空字符串、偽元素字符串,該方法返回一個只讀的表示計算樣式的CSSStyleDeclaration對象,它代表了實際應用在指定元素上的最終樣式信息,即各種CSS規則疊加后的結果;
        如:var color = window.getComputedStyle(elm, ':before').color;
                var color = window.getComputedStyle(elm, ':before').getPropertyValue('color');
        或:var color = window.getComputedStyle(elm, null).color;
 
        表示計算樣式的CSSStyleDeclaration對象與表示內聯樣式的CSSStyleDeclaration對象的區別:
            1.計算樣式的屬性是只讀的;
            2.計算樣式的值是絕對值,類似百分比和點之類相對的單位將全部轉換為以'px'為后綴的字符串絕對值,其值是顏色的屬性將以“rgb(#,#,#)”或“rgba(#,#,#,#)”的格式返回;
            3.不計算復合屬性,只基于最基礎的屬性,如不要查詢margin,而單獨查詢marginTop等;
            4.計算樣式對象未定義cssText屬性;
            5.計算樣式同時具有欺騙性,使用時需注意,在查詢某些屬性時的返回值不一定精準,如查詢font-family;
            6.IE9以下不支持getComputedStyle方法,IE的Element對象有currentStyle屬性;
 
  • 通過CSSStyleDeclaration對象的cssText屬性和setProperty()、removeProperty等方法
如:elm.style.cssText ='color:red;line-height:30px';
                  elm.style.removeProperty('color');
                     elm.style.setProperty('color', 'green', 'important');
                        elm.style.cssText = ''; //快速清空該規則的所有聲明
        每一條CSS規則的樣式聲明部分(大括號內部的部分),都是一個CSSStyleDeclaration對象,它的屬性和方法:
            屬性:
                1.cssText:當前規則的所有樣式聲明文本。該屬性可讀寫,即可用來設置當前規則。
                2.length:當前規則包含多少條聲明。
                3.parentRule:包含當前規則的那條規則,同CSSRule接口的parentRule屬性。
            方法:
                1.getPropertyPriority()方法返回指定聲明的優先級,如果有的話,就是“important”,否則就是空字符串;
                2.getPropertyValue方法返回指定聲明的值;
                3.item(index)方法返回指定位置的屬性名,一般用[index]語法更直接;
                4.removeProperty方法用于刪除一條CSS屬性,返回被刪除的值;
                5.setProperty方法用于設置指定的CSS屬性,沒有返回值;


 
  • window.matchMedia方法用來檢查CSS的mediaQuery語句。各種瀏覽器的最新版本(包括IE 10+)都支持該方法,對于不支持該方法的老式瀏覽器,可以使用第三方函數庫matchMedia.js;
            下面是mediaQuery語句的一個例子:
                @media all and (max-device-width: 700px) {
                      body {background: #FF0;}
                }
        window.matchMedia方法接受一個mediaQuery語句的字符串作為參數,返回一個MediaQueryList對象。該對象有以下兩個屬性:
        media:返回所查詢的mediaQuery語句字符串。
        matches:返回一個布爾值,表示當前環境是否匹配查詢語句。
                var result = window.matchMedia('(max-width: 700px)');
                if (result.matches) {
                      console.log('頁面寬度小于等于700px');
                } else {
                      console.log('頁面寬度大于700px');

                }
        window.matchMedia方法返回的MediaQueryList對象有兩個方法,用來監聽事件:addListener方法和removeListener方法。如果mediaQuery查詢結果發生變化,就調用指定的回調函數;

                var mql =  window.matchMedia("(max-width: 700px)");
                mql.addListener(mqCallback);// 指定回調函數
                mql.removeListener(mqCallback);// 撤銷回調函數
                function mqCallback(mql) {
                      if (mql.matches) {// 寬度小于等于700像素} 
                      else { // 寬度大于700像素}
                }
 
本文參考:
MDN: https://developer.mozilla.org/zh-CN/docs/Web/API
https://www.cnblogs.com/susufufu/p/5749922.html
主站蜘蛛池模板: 2020久久香蕉国产线看观看 | 久久青青操 | 香蕉视频在线免费 | 五月综合激情日本mⅴ | 在线观看免费无码专区 | 午夜精品一区二区三区在线观看 | 日本高清在线天码一区播放 | 国产97人人超碰cao蜜芽prom | 婷婷综合久久中文字幕蜜桃三电影 | 国产视频亚洲精品 | 播播开心激情网 | 国产成人无码18禁午夜福利p | 久久午夜夜伦鲁鲁片不卡 | 欧美wwwxxx | 日韩经典中文字幕 | 成人免费版欧美州 | 99国产精品久久久久久久 | 日皮视频在线观看 | 国产在线精品自拍 | 无码av中文一区二区三区桃花岛 | 国产乱子伦视频在线播放 | 伊人久久亚洲综合影院首页 | 99热中文 | 天天色天| 国产薄丝脚交视频在线观看 | 久久97超碰人人澡人人爱 | 深夜福利av无码一区二区 | 亚洲精品国产suv一区 | 激情呻吟久久久久久99av | 无码人妻精品丰满熟妇区 | 偷窥自拍亚洲色图 | 亚洲综合一区二区三区四区五区 | 国产免费一区二区三区不卡 | 欧美国产激情一区二区在线 | 风韵少妇性饥渴推油按摩视频 | 无码国产精品一区二区免费式芒果 | 成人精品毛片va一区二区三区 | 人人玩人人添人人澡免费 | ∞性videosex女兵 | 亚洲欧美一区二区成人片 | 亚洲高清视频在线播放 | 欧美精品二区三区 | 国产午夜激无码av毛片不卡 | 免费看小12萝裸体视频国产 | 欧美精品乱码99久久蜜桃 | 日日欧美 | 新呦u视频一区二区 | 亚洲另类伦春色综合妖色成人网 | 国产精品久久久久9999不卡 | 色先锋资源久久综合5566 | 136av福利视频导航 | 国产免费人成在线视频网站 | 热99精品 | 少妇精品久久久久www | 亚洲色网址 | 狠狠人妻久久久久久综合蜜桃 | 黄色av日韩 | 国产精品丝袜久久久久久消防器材 | 国产96在线 | 免费 | 亚洲欧美精品沙发 | 亚洲精品自产拍在线观看 | 国产亚洲精品a在线无码 | а√最新版在线天堂 | 欧美 日韩 国产在线 | 久久久久一区 | 在线观看日韩精品视频 | 午夜影院在线免费观看视频 | 国产精品7777777 | 欧美两根一起进3p在线观看 | 亚洲国产成人精品女人久久久 | 黄色一视频 | 久久精品人人做人人爽电影 | 太久av| 欧美精品乱码99久久蜜桃 | 成年片色大黄全免费网站久久高潮 | 亚洲精品国男人在线视频 | 国产免费久久精品99re丫丫 | 色综合久久天天 | a一区二区三区乱码在线 | 欧洲 | 91亚洲福利视频 | 日日干狠狠操 | 成人5g影院_天天5g天天看 | 亚洲成在人线在线播放无码vr | 一本一本久久a久久精品综合妖精 | 欧美男生射精高潮视频网站 | 国产农村妇女毛片精品久久 | 亚洲 国产 另类 精品 专区 | 青青草成人在线 | 18禁亚洲深夜福利入口 | 国产欧美日韩va另类在线播放 | 天天干天天操天天玩 | 在线精品亚洲一区二区小说 | 在线观看免费人成视频色9 动漫av纯肉无码免费播放 | 日日噜噜大屁股熟妇 | 日韩成人高清 | 伊久久| 国产第一页第二页 | 97无码视频在线看视频 | 国产免费无码av片在线观看不卡 |