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

哪些CSS沒用到一目了然:

當(dāng)然,0匹配并不代表它就是沒用的。最典型的例子就是:hover,只有鼠標(biāo)移上去才會匹配。還有通過className控制,[attr=],#動態(tài)ID,動態(tài)元素。。。。等等等等的樣式都不是輕易能匹配到。
所以以上代碼意義并不大,而且目前主流瀏覽器都內(nèi)置Profiles功能,并且能實(shí)時跟蹤選擇器匹配的元素?cái)?shù),所以做個IE版本的才有些意義:)
相關(guān)文章
詳解JS截取字符串的三個方法substring,substr,slice
js中有三個截取字符的方法,分別是substring()、substr()、slice(),平時我們可能都用到過,但總是會對這些方法有點(diǎn)混淆。本文將詳細(xì)介紹一下這三者的區(qū)別,需要的可以參考一下2022-03-03
微信小程序間使用navigator跳轉(zhuǎn)傳值問題實(shí)例分析
這篇文章主要介紹了微信小程序間使用navigator跳轉(zhuǎn)傳值問題,結(jié)合實(shí)例形式分析了微信小程序間使用navigator跳轉(zhuǎn)傳值過程中遇到的問題與解決方法,需要的朋友可以參考下2020-03-03
openlayers實(shí)現(xiàn)圖標(biāo)拖動獲取坐標(biāo)
這篇文章主要為大家詳細(xì)介紹了openlayers實(shí)現(xiàn)圖標(biāo)拖動獲取坐標(biāo),文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下2020-09-09
javascript實(shí)現(xiàn)設(shè)置、獲取和刪除Cookie的方法
這篇文章主要介紹了javascript實(shí)現(xiàn)設(shè)置、獲取和刪除Cookie的方法,涉及javascript操作cookie的常用技巧,非常簡單實(shí)用,需要的朋友可以參考下2015-06-06
php讀取sqlite數(shù)據(jù)庫入門實(shí)例代碼
本文介紹了php讀取sqlite數(shù)據(jù)庫的簡單例子,php編程中操作sqlite入門實(shí)例,有需要的朋友可以參考下2014-06-06
JavaScript中遍歷對象的property的3種方法介紹
這篇文章主要介紹了JavaScript中遍歷對象的property的3種方法介紹,本文先是講解了3種方法并用一張圖片加深理解,然后給出代碼實(shí)例,需要的朋友可以參考下2014-12-12
JS獲取子節(jié)點(diǎn)、父節(jié)點(diǎn)和兄弟節(jié)點(diǎn)的方法實(shí)例總結(jié)
這篇文章主要介紹了JS獲取子節(jié)點(diǎn)、父節(jié)點(diǎn)和兄弟節(jié)點(diǎn)的方法,結(jié)合實(shí)例形式總結(jié)分析了JavaScript針對子節(jié)點(diǎn)、父節(jié)點(diǎn)和兄弟節(jié)點(diǎn)獲取相關(guān)操作技巧與使用注意事項(xiàng),需要的朋友可以參考下2018-07-07

