搜尋
首頁web前端css教學CSS規則層疊的應用 css必須要注意的幾點_經驗交流

理論基礎是必要的,實踐是提升和理解理論的方法,兩者同樣重要,任何設計和開發人員離開這兩者的平衡,不論偏向哪一方,都會範或左或右的錯誤。不過我所講的這個方法在實際應用上到底有什麼用呢。顯然,它不能夠為我們創造出圓角矩形,也不能夠為我們創造出分列佈局,更不可能給我們一個固定在文件頭部的導覽列。這個演算法的實踐應用在於: 良好的css程式規範 。這是一個宏觀的實踐,與我剛才提到的微觀實踐同樣重要,但卻更難掌握。

本文並不想包含所有的良好的css程式設計規範,也不可能,我所能夠提供的也只是我個人編寫css的規範小結,我想這些規範是盡可能靠近css的運作本質的。

不要使用inline css 
user style不在你的掌控之內 
不要使用important規則 
按照特殊性從低到高編寫css 
前三條不是我說的重點,我將一筆帶過。

inline css的特殊性是最高的,如果你css檔案中的屬性與inline css衝突,那麼你css檔案中的屬性無效,這和我們僅在css檔案中對樣式進行debug的習慣不符。 inline css也是醜陋的,它將樣式插入html文檔,所以應放棄使用inline css。

如果使用者將user style設定為important,那麼不論怎麼寫css規則,總是不能覆蓋使用者的important語句,所以試圖覆蓋所有的user style是徒勞的。高興的是我們不需要考慮這些了。

important規則是個異類,它不符合我們慣有的思維方式,不論我們如何增加css規則的特殊性和先後順序,important規則都將涵蓋與它競爭的規則,這也會打亂css規則的習慣規律,給debug帶來麻煩。如果你要 使用important規則來hack瀏覽器 ,那麼你應在一個指向唯一元素的selector中應用該規則。 (ps. hack應當是解決方法中最後考慮的一項,因為它長得太醜陋了。)

最後一點,如何做到按照特殊性從低到高編寫css?

關鍵在於 模組化css 。

新增全域css 
新增目前頁面統一css 
將頁面分成幾個模組 
在每個不同模組上使用id掛鉤,相同模組上使用class掛鉤
新增每個模組的統一css 
將每個模組分成幾個子模組,並且回到步驟4開始循環直到樣式新增完成。 
寫出好的css是一個設計問題,而不是實作問題。我們首先應當將寫出特殊性非常低的全域css內容,也就是我們 常用的reset.css 。它是我們整個網站中所有頁面的預設樣式。

如果有哪個頁面具有獨特的統一樣式,如某一頁的背景與其他頁面不同,那麼我們可以為某一頁添加id,然後在id下編寫當前頁面的統一css。

body#special{ 
    background-color:black; 
}

統一樣式寫好後,我們將頁面分成幾個模組,如果這些模組具有基本相同的樣式,那麼使用class掛鉤,如果樣式並非相同,那麼使用id掛鉤,以後每次分模組時都應遵循這項原則,因為class的特殊性不高,所以如果不是看起來顯然類似的模組,就不應當使用class。 id的名字通常可以模組的用途作為名字。如 head 、 bottom 等。 id selector在層疊中起了關鍵作用,因為id具有排他性,也具有較高的特殊性,能夠防止css規則被不經意的覆蓋。

在某個模組中我們可能有一些統一css,那麼我們就需要在使用id selector來寫目前模組下的統一樣式。

#head p{ 
    color:red; 
}

新增class掛鉤時,我建議使用父模組(或頁面本身)的id在作為class名稱的第一部分。如果我新增一個獨立的頁面(body#special),那麼為該頁面分好模組後,我應當將該頁的模組命名為 special_head 、 special_bottom 等。

或在某些頁面模組中使用class掛鉤時應使用 head_col 等。這樣做的好處是我們不用使用

#head .col{ 
    /* 头部中每一列的样式 */ 
}

而可以直接使用

.head_col{ 
    /* 头部中每一列的样式 */ 
}

而不用擔心命名衝突。

而對於模組下直接加入了id selector的元素,我們可以直接使用該selector,並且也在其名字前面加上父模組的id。

#head_navigator{ 
    /* 头部中导航栏的样式 */ 
}

要做到模組化css我們應盡量防止跨模組的css出現,我想一條好的原則是:如果某一樣式的跨模組特性不是你一目了然的,那就不要使用跨模組的css。一個例外是全域css或模組內的統一css。而對於那些並非一目了然的,並非具有統一樣式的,建議在每個子模組下分別定義。這就像是編寫java程式中的物件導向的設計一樣,我們要降低模組之間的互相依賴,使得相同模組的css規則在一起,略有不同的就完全分開,這樣不但易於維護,還能夠保證特殊性從低到高地編寫css,從而防止css規則被意外的覆蓋

以上就是css規則層疊的應用css必須要注意的幾點_經驗交流的內容,更多相關內容請關注php中文網(www.php.cn)!


陳述
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
@KeyFrames vs CSS過渡:有什麼區別?@KeyFrames vs CSS過渡:有什麼區別?May 14, 2025 am 12:01 AM

@keyframesandCSSTransitionsdifferincomplexity:@keyframesallowsfordetailedanimationsequences,whileCSSTransitionshandlesimplestatechanges.UseCSSTransitionsforhovereffectslikebuttoncolorchanges,and@keyframesforintricateanimationslikerotatingspinners.

使用頁面CMS進行靜態站點內容管理使用頁面CMS進行靜態站點內容管理May 13, 2025 am 09:24 AM

我知道,我知道:有大量的內容管理系統選項可用,而我進行了幾個測試,但實際上沒有一個是一個,y'知道嗎?怪異的定價模型,艱難的自定義,有些甚至最終成為整個&

鏈接HTML中CSS文件的最終指南鏈接HTML中CSS文件的最終指南May 13, 2025 am 12:02 AM

鏈接CSS文件到HTML可以通過在HTML的部分使用元素實現。 1)使用標籤鏈接本地CSS文件。 2)多個CSS文件可通過添加多個標籤實現。 3)外部CSS文件使用絕對URL鏈接,如。 4)確保正確使用文件路徑和CSS文件加載順序,優化性能可使用CSS預處理器合併文件。

CSS Flexbox與網格:全面評論CSS Flexbox與網格:全面評論May 12, 2025 am 12:01 AM

選擇Flexbox還是Grid取決於佈局需求:1)Flexbox適用於一維佈局,如導航欄;2)Grid適合二維佈局,如雜誌式佈局。兩者在項目中可結合使用,提升佈局效果。

如何包括CSS文件:方法和最佳實踐如何包括CSS文件:方法和最佳實踐May 11, 2025 am 12:02 AM

包含CSS文件的最佳方法是使用標籤在HTML的部分引入外部CSS文件。 1.使用標籤引入外部CSS文件,如。 2.對於小型調整,可以使用內聯CSS,但應謹慎使用。 3.大型項目可使用CSS預處理器如Sass或Less,通過@import導入其他CSS文件。 4.為了性能,應合併CSS文件並使用CDN,同時使用工具如CSSNano進行壓縮。

Flexbox vs Grid:我應該學習兩者嗎?Flexbox vs Grid:我應該學習兩者嗎?May 10, 2025 am 12:01 AM

是的,youshouldlearnbothflexboxandgrid.1)flexboxisidealforone-demensional,flexiblelayoutslikenavigationmenus.2)gridexcelstcelsintwo-dimensional,confffferDesignssignssuchasmagagazineLayouts.3)blosebothenHancesSunHanceSlineHancesLayOutflexibilitibilitibilitibilitibilityAnderibilitibilityAndresponScormentilial anderingStruction

軌道力學(或我如何優化CSS KeyFrames動畫)軌道力學(或我如何優化CSS KeyFrames動畫)May 09, 2025 am 09:57 AM

重構自己的代碼看起來是什麼樣的?約翰·瑞亞(John Rhea)挑選了他寫的一個舊的CSS動畫,並介紹了優化它的思維過程。

CSS動畫:很難創建它們嗎?CSS動畫:很難創建它們嗎?May 09, 2025 am 12:03 AM

CSSanimationsarenotinherentlyhardbutrequirepracticeandunderstandingofCSSpropertiesandtimingfunctions.1)Startwithsimpleanimationslikescalingabuttononhoverusingkeyframes.2)Useeasingfunctionslikecubic-bezierfornaturaleffects,suchasabounceanimation.3)For

See all articles

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

Video Face Swap

Video Face Swap

使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

熱工具

mPDF

mPDF

mPDF是一個PHP庫,可以從UTF-8編碼的HTML產生PDF檔案。原作者Ian Back編寫mPDF以從他的網站上「即時」輸出PDF文件,並處理不同的語言。與原始腳本如HTML2FPDF相比,它的速度較慢,並且在使用Unicode字體時產生的檔案較大,但支援CSS樣式等,並進行了大量增強。支援幾乎所有語言,包括RTL(阿拉伯語和希伯來語)和CJK(中日韓)。支援嵌套的區塊級元素(如P、DIV),

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

WebStorm Mac版

WebStorm Mac版

好用的JavaScript開發工具

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發環境

Dreamweaver Mac版

Dreamweaver Mac版

視覺化網頁開發工具