真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯(lián)網(wǎng)站制作重慶分公司

css樣式優(yōu)先,簡述css樣式應(yīng)用的優(yōu)先規(guī)則

Css中樣式的優(yōu)先級

當在一個樣式聲明中使用一個 !important 規(guī)則時,此聲明將覆蓋任何其他聲明。雖然,從技術(shù)上講, !important 與優(yōu)先級無關(guān),但它與最終的結(jié)果直接相關(guān)。使用 !important 是一個 壞習慣 ,應(yīng)該盡量避免,因為這破壞了樣式表中的固有的級聯(lián)規(guī)則 使得調(diào)試找bug變得更加困難了。當兩條相互沖突的帶有 !important 規(guī)則的聲明被應(yīng)用到相同的元素上時,擁有更大優(yōu)先級的聲明將會被采用。

創(chuàng)新互聯(lián)建站是專業(yè)的淳安網(wǎng)站建設(shè)公司,淳安接單;提供成都網(wǎng)站設(shè)計、成都網(wǎng)站建設(shè),網(wǎng)頁設(shè)計,網(wǎng)站設(shè)計,建網(wǎng)站,PHP網(wǎng)站建設(shè)等專業(yè)做網(wǎng)站服務(wù);采用PHP框架,可快速的進行淳安網(wǎng)站開發(fā)網(wǎng)頁制作和功能擴展;專業(yè)做搜索引擎喜愛的網(wǎng)站,專業(yè)的做網(wǎng)站團隊,希望更多企業(yè)前來合作!

一些經(jīng)驗法則:

什么的情況下可以使用 !important:

A) 覆蓋內(nèi)聯(lián)樣式

你的網(wǎng)站上有一個設(shè)定了全站樣式的 CSS 文件,同時你(或是你同事)寫了一些很差的內(nèi)聯(lián)樣式。

全局的CSS文件會在全局范圍內(nèi)設(shè)置網(wǎng)站的外觀,而直接在各個元素上定義的內(nèi)聯(lián)樣式可能會覆蓋您的全局CSS文件。 內(nèi)聯(lián)樣式和!important都被認為是非常不好的做法,但是有時你可以在CSS文件里用!important去覆蓋內(nèi)聯(lián)樣式。

在這種情況下,你就可以在你全局的 CSS 文件中寫一些 !important 的樣式來覆蓋掉那些直接寫在元素上的行內(nèi)樣式。

CSS選擇器、優(yōu)先級以及!important知識總結(jié)

關(guān)于CSS選擇器,首先請看這里: CSS 選擇器參考手冊

通過以上,我們可以將CSS選擇器分為以下幾種:

script async src="http://jsfiddle.net/hysunny/3gwbeu3v/embed/html,css,result/"/script

示例:

說明:以下E表示元素,attr表示屬性,val表示屬性的值。

說明:以下E表示元素

示例:

示例:

示例:

示例:

E:not(s) ,匹配不符合當前選擇器的任何元素

示例:

E:target ,匹配文檔中特定"id"點擊后的效果

示例:

這里我們簡單討論下后代元素選擇器和子元素選擇器的區(qū)別

示例

CSS優(yōu)先級是指CSS樣式在瀏覽器中被解析的 先后順序 。

多重樣式(Mutiple Styles):如果外部樣式、內(nèi)部樣式和內(nèi)聯(lián)樣式同時應(yīng)用于同一個元素,就是多重樣式的使用情況。

一般情況下,( 外部 樣式)External style sheet ( 內(nèi)部 樣式)Internal style sheet ( 內(nèi)聯(lián) 樣式)Inline style

例外 :如果外部樣式放在內(nèi)部樣式的后面,則外部樣式將會覆蓋內(nèi)部樣式。

示例:

給不同的選擇器分配不同的權(quán)值

解釋:

示例

結(jié)果:標簽內(nèi)的數(shù)據(jù)顯示為藍色。

比較樣式的優(yōu)先級是,只需統(tǒng)計不同選擇器的個數(shù),然后與對應(yīng)的權(quán)值相乘即可。根據(jù)結(jié)果便可得出優(yōu)先級。

看到這里,有些同學是不是對!important有點迷惑呀 為什么有了它,就優(yōu)先級最高吶 下面我們再來詳細講一講!important~

!important 是CSS1就定義的語法,作用是提高指定樣式的應(yīng)用優(yōu)先權(quán)。

語法格式: {cssRule !important} ,即寫在定義的最后面,例如: box { color: red !important}

聲明了 !important 的樣式,具有最高的優(yōu)先級,相當于寫在最下面(最后定義)

IE 6.0 不完全 支持!important

IE支持重定義中的!important,例如:

你將會發(fā)現(xiàn)定義了樣式 class="yuanxin" 時,在IE下,字體顯示為紅色(#e00)。

但不支持同一定義中的 !important 。例如:

此時在IE6下不支持,你將會發(fā)現(xiàn)定義了樣式 class="yuanxin" 時,字體顯示為黑色(#000)。

解釋 :

important的樣式屬性和覆蓋它的樣式屬性單獨使用時(不在一個{}里),IE 6.0認為!important優(yōu)先級較高,否則當含!important的樣式屬性被同一個{}里的樣式覆蓋時,IE 6.0認為!important較低!

再舉一個例子:

因為IE 6.0一直都不完全支持這個語法,而其他的瀏覽器都支持。因此我們就可以利用這一點來分別利用!important,我們可以針對IE和非IE瀏覽器設(shè)置不同的樣式,只要在非IE瀏覽器樣式的后面加上!important。

完。

總結(jié)內(nèi)容參考以下:

w3school_CSS 選擇器參考手冊

阮一峰_CSS選擇器筆記

css選擇器優(yōu)先級深入理解

CSS 的優(yōu)先級機制[總結(jié)]

十分感謝你們的分享 n(*≧▽≦*)n

注:原文章首發(fā)于: CSS選擇器、優(yōu)先級以及!important知識總結(jié) ,現(xiàn)遷移至此。

script async src="http://jsfiddle.net/hysunny/3gwbeu3v/embed/html,css,result/"/script

css的優(yōu)先級順序是怎樣的

當創(chuàng)建的樣式表越來越復(fù)雜時,一個標簽的樣式將會受到越來越多的影響,這種影響可能來自周圍的標簽,也可能來自其自身。下面我們從這兩方面去看看 CSS 樣式的優(yōu)先級。

CSS 的繼承性

CSS 的繼承特性指的是應(yīng)用在一個標簽上的那些 CSS 屬性被傳到其子標簽上??聪旅娴?HTML 結(jié)構(gòu):

div

p/p/div

如果?div?有個屬性?color: red,則這個屬性將被?p?繼承,即?p?也擁有屬性?color: red。

由上可見,當網(wǎng)頁比較復(fù)雜, HTML 結(jié)構(gòu)嵌套較深時,一個標簽的樣式將深受其祖先標簽樣式的影響。影響的規(guī)則是:

CSS 優(yōu)先規(guī)則1:?最近的祖先樣式比其他祖先樣式優(yōu)先級高。

例1:

!-- 類名為 son 的 div 的 color 為 blue --div style="color: red"

div style="color: blue"

div class="son"/div

/div/div

如果我們把一個標簽從祖先那里繼承來的而自身沒有的屬性叫做"祖先樣式",那么"直接樣式"就是一個標簽直接擁有的屬性。又有如下規(guī)則:

CSS 優(yōu)先規(guī)則2:"直接樣式"比"祖先樣式"優(yōu)先級高。

例2:

!-- 類名為 son 的 div 的 color 為 blue --div style="color: red"

div class="son" style="color: blue"/div/div

選擇器的優(yōu)先級

上面討論了一個標簽從祖先繼承來的屬性,現(xiàn)在討論標簽自有的屬性。在討論 CSS 優(yōu)先級之前,先說說 CSS 7 種基礎(chǔ)的選擇器:

ID 選擇器, 如 #id{}

類選擇器, 如 .class{}

屬性選擇器, 如 a[href="segmentfault.com"]{}

偽類選擇器, 如 :hover{}

偽元素選擇器, 如 ::before{}

標簽選擇器, 如 span{}

通配選擇器, 如 *{}

CSS 優(yōu)先規(guī)則3:優(yōu)先級關(guān)系:內(nèi)聯(lián)樣式 ID 選擇器 類選擇器 = 屬性選擇器 = 偽類選擇器 標簽選擇器 = 偽元素選擇器

例3:

// HTMLdiv class="content-class" id="content-id" style="color: black"/div// CSS#content-id {

color: red;}.content-class {

color: blue;}div {

color: grey;}

最終的 color 為 black,因為內(nèi)聯(lián)樣式比其他選擇器的優(yōu)先級高。

所有 CSS 的選擇符由上述 7 種基礎(chǔ)的選擇器或者組合而成,組合的方式有 3 種:

后代選擇符: .father .child{}

子選擇符: .father .child{}

相鄰選擇符: .bro1 + .bro2{}

當一個標簽同時被多個選擇符選中,我們便需要確定這些選擇符的優(yōu)先級。我們有如下規(guī)則:

CSS 優(yōu)先規(guī)則4:計算選擇符中 ID 選擇器的個數(shù)(a),計算選擇符中類選擇器、屬性選擇器以及偽類選擇器的個數(shù)之和(b),計算選擇符中標簽選擇器和偽元素選擇器的個數(shù)之和(c)。按 a、b、c 的順序依次比較大小,大的則優(yōu)先級高,相等則比較下一個。若最后兩個的選擇符中 a、b、c 都相等,則按照"就近原則"來判斷。

例4:

// HTMLdiv id="con-id"

span class="con-span"/span/div// CSS#con-id span {

color: red;}div .con-span {

color: blue;}

由規(guī)則 4 可見,span 的 color 為 red。

如果外部樣式表和內(nèi)部樣式表中的樣式發(fā)生沖突會出現(xiàn)什么情況呢?這與樣式表在 HTML 文件中所處的位置有關(guān)。樣式被應(yīng)用的位置越在下面則優(yōu)先級越高,其實這仍然可以用規(guī)則 4 來解釋。

例5:

// HTMLlink rel="stylesheet" type="text/css" href="style-link.css"style type="text/css"@import url(style-import.css); div {

background: blue;}/stylediv/div// style-link.cssdiv {

background: lime;}// style-import.cssdiv {

background: grey;}

從順序上看,內(nèi)部樣式在最下面,被最晚引用,所以 div 的背景色為 blue。

上面代碼中,@import?語句必須出現(xiàn)在內(nèi)部樣式之前,否則文件引入無效。當然不推薦使用?@import?的方式引用外部樣式文件,原因見另一篇博客:CSS 引入方式。

CSS 還提供了一種可以完全忽略以上規(guī)則的方法,當你一定、必須確保某一個特定的屬性要顯示時,可以使用這個技術(shù)。

CSS 優(yōu)先規(guī)則5:屬性后插有?!important?的屬性擁有最高優(yōu)先級。若同時插有?!important,則再利用規(guī)則 3、4 判斷優(yōu)先級。

例6:

// HTMLdiv class="father"

p class="son"/p/div// CSSp {

background: red !important;}.father .son {

background: blue;}

雖然 .father .son 擁有更高的權(quán)值,但選擇器 p 中的 background 屬性被插入了 !important, 所以 p 的 background 為 red。

錯誤的說法

在學習過程中,你可能發(fā)現(xiàn)給選擇器加權(quán)值的說法,即 ID 選擇器權(quán)值為 100,類選擇器權(quán)值為 10,標簽選擇器權(quán)值為 1,當一個選擇器由多個 ID 選擇器、類選擇器或標簽選擇器組成時,則將所有權(quán)值相加,然后再比較權(quán)值。這種說法其實是有問題的。比如一個由 11 個類選擇器組成的選擇器和一個由 1 個 ID 選擇器組成的選擇器指向同一個標簽,按理說 110 100,應(yīng)該應(yīng)用前者的樣式,然而事實是應(yīng)用后者的樣式。錯誤的原因是:權(quán)重的進制是并不是十進制,CSS 權(quán)重進制在 IE6 為 256,后來擴大到了 65536,現(xiàn)代瀏覽器則采用更大的數(shù)量。。還是拿剛剛的例子說明。11 個類選擇器組成的選擇器的總權(quán)值為 110,但因為 11 個均為類選擇器,所以其實總權(quán)值最多不能超過 100, 你可以理解為 99.99,所以最終應(yīng)用后者樣式。

CSS 優(yōu)先級

繼承得到的樣式的優(yōu)先級是最低的;最近的祖先樣式比其他祖先樣式優(yōu)先級高;"直接樣式"比"祖先樣式"優(yōu)先級高。

1、無繼承性的屬性

①? display:規(guī)定元素應(yīng)該生成的框的類型

②? 文本屬性:

vertical-align:垂直文本對齊

text-decoration:規(guī)定添加到文本的裝飾

text-shadow:文本陰影效果

white-space:空白符的處理

unicode-bidi:設(shè)置文本的方向

③? 盒子模型的屬性:width、height、margin 、margin-top、margin-right、margin-bottom、margin-left、border、 border-style、border-top-style、border-right-style、border-bottom-style、border-left-style、border-width、border-top-width、border-right-right、border-bottom-width、border-left-width、border-color、border-top-color、border-right-color、border-bottom-color、border-left-color、border-top、border-right、border-bottom、border-left、padding、padding-top、padding-right、padding-bottom、padding-left

④? 背景屬性:background、background-color、background-image、background-repeat、background-position、background-attachment

⑤? 定位屬性:float、clear、position、top、right、bottom、left、min-width、min-height、max-width、max-height、overflow、clip、z-index

⑥? 生成內(nèi)容屬性:content、counter-reset、counter-increment

⑦? 輪廓樣式屬性:outline-style、outline-width、outline-color、outline

⑧? 頁面樣式屬性:size、page-break-before、page-break-after

⑨? 聲音樣式屬性:pause-before、pause-after、pause、cue-before、cue-after、cue、play-during

2、有繼承性的屬性

①? 字體系列屬性

font:組合字體

font-family:規(guī)定元素的字體系列

font-weight:設(shè)置字體的粗細

font-size:設(shè)置字體的尺寸

font-style:定義字體的風格

font-variant:設(shè)置小型大寫字母的字體顯示文本,這意味著所有的小寫字母均會被轉(zhuǎn)換為大寫,但是所有使用小型大寫 字體的字母與其余文本相比,其字體尺寸更小。

font-stretch:對當前的 font-family 進行伸縮變形。所有主流瀏覽器都不支持。

font-size-adjust:為某個元素規(guī)定一個 aspect 值,這樣就可以保持首選字體的 x-height。

②?文本系列屬性

text-indent:文本縮進

text-align:文本水平對齊

line-height:行高

word-spacing:增加或減少單詞間的空白(即字間隔)

letter-spacing:增加或減少字符間的空白(字符間距)

text-transform:控制文本大小寫

direction:規(guī)定文本的書寫方向

color:文本顏色 a元素除外

③? 元素可見性:visibility

④? 表格布局屬性:caption-side、border-collapse、border-spacing、empty-cells、table-layout

⑤? 列表布局屬性:list-style-type、list-style-image、list-style-position、list-style

⑥? 生成內(nèi)容屬性:quotes

⑦? 光標屬性:cursor

⑧? 頁面樣式屬性:page、page-break-inside、windows、orphans

⑨? 聲音樣式屬性:speak、speak-punctuation、speak-numeral、speak-header、speech-rate、volume、voice-family、 pitch、pitch-range、stress、richness、、azimuth、elevation

3、所有元素可以繼承的屬性

①? 元素可見性:visibility

②? 光標屬性:cursor

4、內(nèi)聯(lián)元素可以繼承的屬性

①? 字體系列屬性

②? ?除text-indent、text-align之外的文本系列屬性

5、塊級元素可以繼承的屬性

?text-indent、text-align

CSS 7 種基礎(chǔ)的選擇器:

ID 選擇器, 如 #id{}

類選擇器, 如 .class{}

屬性選擇器, 如 a[href="segmentfault.com"]{}

偽類選擇器, 如 :hover{}

偽元素選擇器, 如 ::before{}

標簽選擇器, 如 span{}

通配選擇器, 如 *{}

優(yōu)先級關(guān)系 :內(nèi)聯(lián)樣式 ID 選擇器 類選擇器 = 屬性選擇器 = 偽類選擇器 標簽選擇器 = 偽元素選擇器

屬性后插有?!important?的屬性擁有最高優(yōu)先級

:is()和:not():其偽類在計算選擇器數(shù)量時當做普通選擇器進行計數(shù)。

css的三種樣式中哪種樣式的優(yōu)先級最高

css樣式采取的就近樣式原則。

行內(nèi)樣式div style=""/div優(yōu)先級最高,沒有行內(nèi)樣式那么會回在頁答面找style/style內(nèi)嵌樣式。

名稱CSS中的“層疊(cascading)”表示樣式單規(guī)則應(yīng)用于HTML文檔元素的方式。具體地說,CSS樣式單中的樣式形成一個層次結(jié)構(gòu),更具體的樣式覆蓋通用樣式。樣式規(guī)則的優(yōu)先級由CSS根據(jù)這個層次結(jié)構(gòu)決定,從而實現(xiàn)級聯(lián)效果。

擴展資料:

易于使用和修改:

CSS可以將樣式定義在HTML元素的style屬性中,也可以將其定義在HTML文檔的header部分,也可以將樣式聲明在一個專門的CSS文件中,以供HTML頁面引用??傊?,CSS樣式表可以將所有的樣式聲明統(tǒng)一存放,進行統(tǒng)一管理。

另外,可以將相同樣式的元素進行歸類,使用同一個樣式進行定義,也可以將某個樣式應(yīng)用到所有同名的HTML標簽中。

參考資料來源:百度百科-CSS


分享文章:css樣式優(yōu)先,簡述css樣式應(yīng)用的優(yōu)先規(guī)則
網(wǎng)址分享:http://weahome.cn/article/dsdohoi.html

其他資訊

在線咨詢

微信咨詢

電話咨詢

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部