只需20行代碼就可以寫(xiě)出CSS覆蓋率測(cè)試腳本
document.styleSheets里保存了當(dāng)前頁(yè)面上所有CSS規(guī)則的集合。通過(guò)它可以遍歷出頁(yè)面<style>里定義的所有selector,訪問(wèn)selectorText屬性可得選擇器的匹配規(guī)則。然后將規(guī)則規(guī)則傳遞給 document.querySelectorAll 即可獲取頁(yè)面內(nèi)匹配此規(guī)則的元素列表。
這里我們只求CSS規(guī)則的覆蓋率,所以訪問(wèn) querySelectorAll().length 即可。通過(guò)排序就可看出各個(gè)CSS使用情況。
代碼很簡(jiǎn)單。
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)限問(wèn)題,外部導(dǎo)入的CSS無(wú)論如何都訪問(wèn)不到,暫時(shí)先不考慮了。至于不支持styleSheets的破IE嘛,可以考慮用expression或者behaviour.htc,改天試試看。
順便貼個(gè)測(cè)試結(jié)果:

相關(guān)文章
使用HTML+CSS+JS制作簡(jiǎn)單的網(wǎng)頁(yè)菜單界面
這篇文章主要介紹了使用HTML+CSS+JS制作簡(jiǎn)單的網(wǎng)頁(yè)菜單界面,這個(gè)ABROAD項(xiàng)目所使用的JavaScript部分代碼非常簡(jiǎn)單,需要的朋友可以參考下2015-07-07
javascript內(nèi)置對(duì)象arguments詳解
這篇文章主要介紹了javascript內(nèi)置對(duì)象arguments,實(shí)例講解arguments是什么怎么用,需要的朋友可以參考下2014-03-03
說(shuō)說(shuō)掌握J(rèn)avaScript語(yǔ)言的思想前提想學(xué)習(xí)js的朋友可以看看
無(wú)論是公司的同事還是外界的程序員朋友們,大部分人對(duì)JavaScript的高級(jí)應(yīng)用不甚了解,已有的知識(shí)架構(gòu)里會(huì)認(rèn)為JavaScript僅僅是一門腳本語(yǔ)言,其作用是給頁(yè)面做一些錦上添花的效果,比如表單驗(yàn)證等等。2009-04-04

