国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 語言 > JavaScript > 正文

20行代碼實(shí)現(xiàn)的一個(gè)CSS覆蓋率測(cè)試腳本

2024-05-06 15:48:45
字體:
供稿:網(wǎng)友
這里我們只求CSS規(guī)則的覆蓋率,所以訪問 querySelectorAll().length 即可。通過排序就可看出各個(gè)CSS使用情況

document.styleSheets里保存了當(dāng)前頁面上所有CSS規(guī)則的集合。通過它可以遍歷出頁面<style>里定義的所有selector,訪問selectorText屬性可得選擇器的匹配規(guī)則。然后將規(guī)則規(guī)則傳遞給 document.querySelectorAll 即可獲取頁面內(nèi)匹配此規(guī)則的元素列表。
這里我們只求CSS規(guī)則的覆蓋率,所以訪問 querySelectorAll().length 即可。通過排序就可看出各個(gè)CSS使用情況。
代碼很簡(jiǎn)單。

復(fù)制代碼 代碼如下:


var usage = [];
var sheets = document.styleSheets;

for(var i = sheets.length - 1; i != -1; i--) {
    var rules = sheets[i].rules;

    for(var j = rules.length - 1; j != -1; j--) {
        var rule = rules[j];
        var text = rule.selectorText;

        usage.push({name: text, count: document.querySelectorAll(text).length});
    }
}
usage.sort(function(a, b){return a.count - b.count});

for(var i = usage.length - 1; i != -1; i--) {
    console.log("選擇器:" + usage[i].name + "/n/t匹配數(shù):" + usage[i].count);
}

呼出F12,把代碼粘到console里回車即可。

當(dāng)然由于權(quán)限問題,外部導(dǎo)入的CSS無論如何都訪問不到,暫時(shí)先不考慮了。至于不支持styleSheets的破IE嘛,可以考慮用expression或者behaviour.htc,改天試試看。
純JS實(shí)現(xiàn)就到此。以后配合本地程序?qū)崿F(xiàn)外部CSS的分析。

順便貼個(gè)測(cè)試結(jié)果:

20行代碼實(shí)現(xiàn)的一個(gè)CSS覆蓋率測(cè)試腳本

哪些CSS沒用到一目了然:

20行代碼實(shí)現(xiàn)的一個(gè)CSS覆蓋率測(cè)試腳本

當(dāng)然,0匹配并不代表它就是沒用的。最典型的例子就是:hover,只有鼠標(biāo)移上去才會(huì)匹配。還有通過className控制,[attr=],#動(dòng)態(tài)ID,動(dòng)態(tài)元素。。。。等等等等的樣式都不是輕易能匹配到。

所以以上代碼意義并不大,而且目前主流瀏覽器都內(nèi)置Profiles功能,并且能實(shí)時(shí)跟蹤選擇器匹配的元素?cái)?shù),所以做個(gè)IE版本的才有些意義:)

發(fā)表評(píng)論 共有條評(píng)論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表

圖片精選

主站蜘蛛池模板: 天峻县| 鸡西市| 商洛市| 右玉县| 安吉县| 景宁| 台前县| 徐水县| 都江堰市| 湘乡市| 呼和浩特市| 包头市| 湘潭县| 武义县| 长兴县| 府谷县| 宁河县| 朝阳县| 闸北区| 隆尧县| 图木舒克市| 扎鲁特旗| 台南县| 光山县| 鹤庆县| 绥滨县| 太康县| 徐闻县| 临城县| 商都县| 常州市| 鱼台县| 仪征市| 余江县| 桐庐县| 石林| 绩溪县| 仪陇县| 西宁市| 邯郸县| 三门峡市|