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

首頁 > 開發 > CSS > 正文

了解CSS的查找匹配原理

2024-07-11 09:01:11
字體:
來源:轉載
供稿:網友

  看1個簡單的CSS: 

DIV#divBox p span.red{color:red;},按習慣我們對這個CSS 的理解是,瀏覽器先查找id為divBox的DIV元素,當找到后,再找其下的所有p元素,然后再查找所有span元素,當發現有span的class為red的時候,就應用該style。多么簡單易懂的原理,可是這個理解卻是完完全全相反、錯誤的。 


匹配原理: 

瀏覽器CSS匹配不是從左到右進行查找,而是從右到左進行查找。比如之前說的 DIV#divBox p span.red{color:red;},瀏覽器的查找順序如下: 

先查找html中所有class='red'的span元素,找到后,再查找其父輩元素中是否有p元素,再判斷p的父元素中是否有id為divBox的div元素,如果都存在則匹配上。 

瀏覽器從右到左進行查找的好處是為了盡早過濾掉一些無關的樣式規則和元素。比如如下html和css: 

 代碼如下:

  <style> 
DIV#divBox p span.red{color:red;} 
<style> 
<body> 
<div id="divBox"> 
<p><span>s1</span></p> 
<p><span>s2</span></p> 
<p><span>s3</span></p> 
<p><span class='red'>s4</span></p> 
</div> 
</body> 


如果按從左到右查找,哪會先查找到很多不相關的p和span元素。而如果按從右到左的方式進行查找,則首先就查找到<span class='red'>的元素。firefox稱這種查找方式為key selector(關鍵字查詢),所謂的關鍵字就是樣式規則中最后(最右邊)的規則,上面的key就是span.red。 


簡潔、高效的CSS: 
所謂高效的CSS就是讓瀏覽器在查找style匹配的元素的時候盡量進行少的查找,下面列出一些我們常見的寫CSS犯一些低效錯誤(也是我以前常常犯的錯誤,還老以為這樣寫才是高效的): 

1.不要在ID選擇器前使用標簽名 
一般寫法:DIV#divBox 
更好寫法:#divBox 
解釋: 因為ID選擇器是唯一的,加上div反而增加不必要的匹配。 

2.不要再class選擇器前使用標簽名 
一般寫法:span.red 
更好寫法:.red 
解釋: 同第一條,但如果你定義了多個.red,而且在不同的元素下是樣式不一樣,則不能去掉,比如你css文件中定義如下: 
p.red{color:red;} 
span.red{color:#ff00ff} 
如果是這樣定義的就不要去掉,去掉后就會混淆,不過建議最好不要這樣寫 
3.盡量少使用層級關系 
一般寫法:#divBox p .red{color:red;} 
更好寫法:.red{..} 

4.使用class代替層級關系 
一般寫法:#divBox ul li a{display:block;} 
更好寫法:.block{display:block;} 

PS:看有些同學對從右到左的理論保持懷疑,下面貼出firefox和google的2篇相關css解釋的文章,供大家參考 

mozilla firefox:

google page-speed:l

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 利津县| 额敏县| 花莲县| 湟源县| 同江市| 曲靖市| 临沂市| 柳林县| 体育| 洪泽县| 秭归县| 太谷县| 句容市| 巨鹿县| 临洮县| 米易县| 百色市| 星子县| 积石山| 东兰县| 融水| 长汀县| 武鸣县| 弥渡县| 临漳县| 牡丹江市| 页游| 林西县| 玛纳斯县| 新化县| 来凤县| 东辽县| 克什克腾旗| 定边县| 南宁市| 墨江| 嫩江县| 岳西县| 息烽县| 澳门| 四子王旗|