詳解CSS選擇器、優先級與匹配原理

選擇器種類

????? 嚴格來講,選擇器的種類可以分為三種:標簽名選擇器、類選擇器和ID選擇器。而所謂的后代選擇器和群組選擇器只不過是對前三種選擇器的擴展應用。而在標簽內寫入style=""的方式,應該是CSS的一種引入方式,而不是選擇器,因為根本就沒有用到選擇器。而一般人們將上面這幾種方式結合在一起,所以就有了5種或6種選擇器了。


基本的選擇器類型

語法如下:

  • 通用選擇器,如*{}。
  • 標簽名選擇器,如:p{},即直接使用HTML標簽作為選擇器。
  • 類選擇器,如.citys{}。
  • ID選擇器,如#citys{}。

注意,ID選擇器跟類選擇器有很大的不同:一個頁面內不能出現相同的ID;再就是ID也是后臺開發人員會經常用的,所以前端開發人員應該盡量少的使用。當然跟后臺人員的工作配合十分嫻熟之后,這些都不會成為限制。


擴展選擇器

  • 后代選擇器,如.citys span img{},后代選賊器實際上是使用多個選擇器加上中間的空格來找到具體的要控制標簽。
  • 群組選擇器,如div,span,img{},群組選擇器實際上是對CSS的一種簡化寫法,只不過把有相同定義的不同選擇器放在一起,省了很多代碼。


選擇器的優先級別

了解了各種選擇器后,還有一個重要的知識點就是CSS選擇器的優先級。舉個簡單的例子:

<div class="citys"> <span class="beijing"> 北京 </span> <span> 上海	  </span> 
</div> 
如果已經把.citys下span內的字體設置成紅色:

.citys span {color:red;} 

這時,如果要改變.beijing的顏色為藍色,用下面的命令是不能實現的:

.beijing {color:blue;} 

出現這種情況就是因為后一個命令的優先級不夠,兩條相互沖突的樣式設置,瀏覽器只會執行優先級較高的那個。


那么選擇器的優先級是怎么規定的呢?

?????? 一般而言,選擇器越特殊,它的優先級越高。也就是選擇器指向的越準確,它的優先級就越高。通常我們用1表示標簽名選擇器的優先級,用10表示類選擇器的優先級,用100標示ID選擇器的優先級。比如上例當中 .citys span {color:red;}的選擇器優先級是 10 + 1 也就是11;而 .polaris 的優先級是10;瀏覽器自然會顯示紅色的字。理解了這個道理之后下面的優先級計算自是易如反掌:

div.test1 .span var 優先級 1+10 +10 +1  
span#xxx .songs li 優先級1+100 + 10 + 1  
#xxx li 優先級 100 +1 

對于什么情況下使用什么選擇器,用不同選擇器的原則是:

第一:準確的選到要控制的標簽;

第二:使用最合理優先級的選擇器;

第三:HTML和CSS代碼盡量簡潔美觀。

通常:

1、最常用的選擇器是類選擇器。
2、li、td、dd等經常大量連續出現,并且樣式相同或者相類似的標簽,我們采用類選擇器跟標簽名選擇器結合的后代選擇器 .xx li td dd {} 的方式選擇。
3、極少的情況下會用ID選擇器,當然很多前端開發人員喜歡header,footer,banner,conntent設置成ID選擇器的,因為相同的樣式在一個頁面里不可能有第二次。

在這里不得不提使用在標簽內引入CSS的方式來寫CSS,即:

<div style="color:red">北京</div> 
這時候的優先級是最高的。我們給它的優先級是1000,這種寫法不推薦使用,特別是對新手來說。這也完全違背了內容和顯示分離的思想。DIV+CSS的優點也不能再有任何體現。

后代選擇器的定位原則


在這里介紹一下對于后代選擇器,瀏覽器是如何查找元素的呢?

??????? 瀏覽器CSS匹配不是從左到右進行查找,而是從右到左進行查找。比如DIV#divBox p span.red{color:red;},瀏覽器的查找順序如下:先查找html中所有class='red'的span元素,找到后,再查找其父輩元素中是否有p元素,再判斷p的父元素中是否有id為divBox的div元素,如果都存在則匹配上。

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

CSS:
#divBox p span.red{color:red;}  HTML:
<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犯一些低效錯誤:

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

◆不要再class選擇器前使用標簽名
一般寫法:span.red
更好寫法:.red
解釋:同第一條,但如果你定義了多個.red,而且在不同的元素下是樣式不一樣,則不能去掉,比如你css文件中定義如下:

p.red{color:red;}  
span.red{color:#ff00ff} 
如果是這樣定義的就不要去掉,去掉后就會混淆,不過建議最好不要這樣寫

◆盡量少使用層級關系
一般寫法:#divBox p .red{color:red;}
更好寫法:.red{..}

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







本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/373769.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/373769.shtml
英文地址,請注明出處:http://en.pswp.cn/news/373769.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

關于299$的企業開發者賬號的申請流程

299$的企業開發者賬號 Apple Developer Enterprise Program?一年1988人民幣 - 企業 (Apple Developer Enterprise Program)- 公司應在鄧白氏注冊并擁有有效的 DUNS 號碼。&#xff0d;此計劃使開發者能夠開發針對 Apple 設備的應用程式&#xff0c;并對其員工進行發布&#xf…

keras 多層lstm_tensorflow-如何在keras中堆疊多個lstm?

DanielAdiwardana的答案的詳細說明。我們需要為除最后一層之外的所有LSTM層添加return_sequences True。將此標志設置為True可讓Keras知道LSTM輸出應包含所有歷史生成的輸出以及時間戳(3D)。 因此&#xff0c;下一個LSTM層可以進一步處理數據。如果此標志為假&#xff0c;則LS…

Java堆空間– JRockit和IBM VM

本文將為您提供JRockit Java堆空間與HotSpot VM的概述。 它還將為您提供有關JRockit和HotSpot的Oracle未來計劃的一些背景知識。 Oracle JRockit VM Java堆&#xff1a;2個不同的內存空間 -Java堆&#xff08;YoungGen和OldGen&#xff09; -本機內存空間&#xff08;類池&am…

如何搭建lamp(CentOS7+Apache+MySQL+PHP)環境 [轉]

在網上搜資料,自己在本地虛擬機上嘗試搭建,弄了整整一天一夜,終于弄好了.網上的資料,雖然很多,但大多都是重復的,拿去試了之后,又很多都不能得到正確的結果.最終找到了適合我的linux環境的搭建方式;在這里貼出來:Install Apache, PHP And MySQL On CentOS 7 (LAMP)度娘真不給力…

為什么要用!DOCTYPE聲明

實例&#xff1a; 我們經常會看到類似這樣的代碼&#xff1a; <!DOCTYPE html> <html> <head> <title>文檔的標題</title> </head> <body> 文檔的內容...... </body> </html>注解&#xff1a;可以看到最上面有一行關于“…

java 線程的開始、暫停、繼續

Android項目中的一個需求&#xff1a;通過線程讀取文件內容&#xff0c;并且可以控制線程的開始、暫停、繼續&#xff0c;來控制讀文件。在此記錄下。 直接在主線程中&#xff0c;通過wait、notify、notifyAll去控制讀文件的線程&#xff08;子線程&#xff09;&#xff0c;報錯…

為什么要在Java中使用Unchecked異常而不是Checked異常

關于檢查與未檢查的異常的爭論可以追溯到過去。 有人說這是Java包含的最佳功能之一。 其他人則說這是他們最大的錯誤之一[ 1 ]。 辯論似乎結束了。 在這篇文章中&#xff0c;我將嘗試包含指向該主題的文章和書籍的鏈接。 我不是專家&#xff0c;但是我會盡力向您解釋為什么我得…

batchplot插件用法_Batchplot批量打印怎么用?Batchplot批量打印教程

很多從事CAD設計工作的用戶都碰到過這種情況&#xff1a;在一個單DWG格式的圖紙文件中包含有大量圖紙&#xff0c;如果一張一張選取打印不但費時費力&#xff0c;而且容易遺漏某張圖紙&#xff0c;這時候就需要用到Batchplot插件&#xff0c;這是專門針對單DWG多圖紙的批量打印…

選擇排序和冒泡排序以及折半查找

1.選擇排序 2.冒泡排序 3.折半查找 方式一&#xff1a;開發使用的方法 方式二&#xff1a;普通的折半 轉載于:https://www.cnblogs.com/juncaoit/p/5935068.html

JSP中Request屬性范圍

JSP屬性范圍&#xff0c;通過以下幾個測試代碼來學習request屬性的范圍 測試一(JSP動態指令方式傳參)&#xff1a; 測試內容&#xff1a; <jsp:param .../>添加參數,通過<jsp:forward page"...">來實現服務器端跳轉,以此來測試request屬性的范圍&#…

Spring MVC – Flash屬性

最新的Spring Framework版本&#xff08;3.1&#xff09;帶來了有趣的功能&#xff0c;稱為Flash屬性。 這是對我很久以前在我的一篇文章中提到的問題的補救措施&#xff1a; Spring MVC –會話屬性處理。 這個問題可以用幾句話來形容&#xff1a;如果我們想通過兩個控制器之間…

000 快速排序算法

一&#xff1a;概述 快速排序是東尼.霍爾所發展的一種快速排序算法。 對于n個項目的排序&#xff0c;平均O&#xff08;n*logn&#xff09;次比較&#xff0c;在比較糟糕的情況下是O&#xff08;n2&#xff09;次比較。 采用分治策略把一個串行分為兩個子串行。 二&#xff1a;…

nginx post請求超時_nginx記錄分析網站響應慢的請求(ngx_http_log_request_speed)

nginx模塊ngx_http_log_request_speed可以用來找出網站哪些請求很慢&#xff0c;針對站點很多&#xff0c;文件以及請求很多想找出哪些請求比較慢的話&#xff0c;這個插件非常有效.作者的初衷是寫給自己用的&#xff0c;用來找出站點中處理時間較長的請求, 這些請求是造成服務…

如何用angularjs制作一個完整的表格之一__創建簡單表格

初步接手人生的第一個項目&#xff0c;需要用angularjs制作表格和實現各種功能&#xff0c;因此遇到了各種問題和以前不熟悉的知識點&#xff0c;在此記錄下來&#xff0c;以供大家學習交流&#xff0c;解決方式可能并不完善或符合規范&#xff0c;如果大家有更好的方式歡迎指出…

Java的String類是上帝的對象嗎?

10月&#xff0c;我寫了一個博客&#xff0c;題為“上帝對象中的頂級特朗普”&#xff0c;其中談到了用167種不同的方法發現的對象的發現&#xff0c;這些方法將該對象與應用程序的所有其他部分鏈接在一起&#xff0c;并且正如您所期望的那樣&#xff0c;上帝或怪物物的一般標準…

十步完全理解SQL

很多程序員視 SQL 為洪水猛獸。SQL 是一種為數不多的聲明性語言&#xff0c;它的運行方式完全不同于我們所熟知的命令行語言、面向對象的程序語言、甚至是函數語言&#xff08;盡管有些人認為 SQL 語言也是一種函數式語言&#xff09;。 我們每天都在寫 SQL 并且應用在開源軟件…

curl命令java_上curl java 模擬http請求

最近&#xff0c;我的項目要求java模擬http請求&#xff0c;獲得dns解決 tcp處理過的信息特定的連接。java api提供urlConnection apache提供的httpClient都不能勝任該需求&#xff0c;二次開發太費時間。于是google之。最后 得出兩種解決的方法&#xff1a;一是使用HTTP4J。該…

androidstudio 優化gradle編譯效率

androidstuido 使用gradle自己主動構建和編譯。有時做少量改動編譯須要等待時間過長&#xff0c;近期Erik Hellman編寫的Boosting the performance for Gradle in your Android projects&#xff08; 譯文 參考1&#xff09;提到了此問題的優化方法。1.gradle的升級到2.4 。 2.…

Common Knowledge_快速冪

問題 I: Common Knowledge 時間限制: 1 Sec 內存限制: 64 MB提交: 9 解決: 8[提交][狀態][討論版]題目描述 Alice and Bob play some game in which they score points. Each of the two has an n-digit scoreboard which depicts numbers in base 10 (with leading zeroes).…

播放2.0:Akka,Rest,Json和依賴項

在過去的幾個月中&#xff0c;我越來越多地涉足scala。 Scala與“ Play框架”一起為您提供了一個非常有效且快速的開發環境&#xff08;即&#xff0c;您掌握了Scala語言的特質之后&#xff09;。 Play框架背后的家伙一直在努力開發新版本的Play 2.0。 在Play 2.0中&#xff0c…