欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

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

 更新時(shí)間:2013年07月07日 23:31:14   作者:  
這里我們只求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é)果:

哪些CSS沒用到一目了然:

當(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版本的才有些意義:)

相關(guān)文章

  • 超詳細(xì)的javascript數(shù)組方法匯總

    超詳細(xì)的javascript數(shù)組方法匯總

    這篇文章主要對(duì)javascript的數(shù)組方法進(jìn)行了詳細(xì)的匯總,包括了最常用的的數(shù)組方法,還有擴(kuò)展方法,很全面,感興趣的小伙伴們可以參考一下
    2015-11-11
  • js日歷相關(guān)函數(shù)使用詳解

    js日歷相關(guān)函數(shù)使用詳解

    這篇文章主要為大家詳細(xì)介紹了js日歷相關(guān)函數(shù)的使用方法,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2022-04-04
  • uniapp自定義下拉刷新組件項(xiàng)目實(shí)踐總結(jié)分析

    uniapp自定義下拉刷新組件項(xiàng)目實(shí)踐總結(jié)分析

    在日常的開發(fā)過程中,我們經(jīng)常遇到下拉刷新的場(chǎng)景,很方便的刷新游覽的內(nèi)容,在此實(shí)現(xiàn)了一個(gè)下拉刷新的自定義組件,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步
    2023-09-09
  • JS實(shí)現(xiàn)的base64加密解密完整實(shí)例

    JS實(shí)現(xiàn)的base64加密解密完整實(shí)例

    這篇文章主要介紹了JS實(shí)現(xiàn)的base64加密解密,以完整實(shí)例形式分析了JavaScript基于base64編碼實(shí)現(xiàn)加密與解密的具體步驟與相關(guān)技巧,并附帶了相關(guān)的加密解密在線工具地址供大家參考,需要的朋友可以參考下
    2016-04-04
  • self.attachevent is not a function的解決方法

    self.attachevent is not a function的解決方法

    今天一個(gè)客戶用chrome瀏覽器訪問網(wǎng)站,他的網(wǎng)站js提示self.attachevent is not a function,這個(gè)問題就是這個(gè)瀏覽器不支持attachevent,可以通過如下方法解決了,分享一下,需要的朋友可以參考下
    2017-04-04
  • 使用layui實(shí)現(xiàn)樹形結(jié)構(gòu)的方法

    使用layui實(shí)現(xiàn)樹形結(jié)構(gòu)的方法

    今天小編就為大家分享一篇使用layui實(shí)現(xiàn)樹形結(jié)構(gòu)的方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧
    2019-09-09
  • 淺談js獲取ModelAndView值的問題

    淺談js獲取ModelAndView值的問題

    下面小編就為大家分享一篇淺談js獲取ModelAndView值的問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧
    2018-03-03
  • Javascript玩轉(zhuǎn)繼承(一)

    Javascript玩轉(zhuǎn)繼承(一)

    最近一直在學(xué)Javascript,打算寫一些文章,算做自己的學(xué)習(xí)心得吧,也可以算是學(xué)習(xí)筆記。沒有系統(tǒng)的知識(shí)點(diǎn),太基礎(chǔ)的不想寫,主要是寫一些自己覺得有價(jià)值的地方
    2014-05-05
  • javascript實(shí)現(xiàn)顏色漸變的方法

    javascript實(shí)現(xiàn)顏色漸變的方法

    這篇文章介紹了javascript實(shí)現(xiàn)顏色漸變的方法,有需要的朋友可以參考一下
    2013-10-10
  • javascript的offset、client、scroll使用方法詳解

    javascript的offset、client、scroll使用方法詳解

    javascript的offset、client、scroll在使用過程中非常頻繁,接下來將對(duì)此進(jìn)行一一介紹,需要了解的朋友可以詳細(xì)參考下
    2012-12-12

最新評(píng)論