GitHub倡導(dǎo)的CSS編寫風(fēng)格及文件目錄部署指南

這個CSS風(fēng)格指南是在GitHub內(nèi)部用于應(yīng)用程序的指南。我們鼓勵您建立一個適合你自己團(tuán)隊的風(fēng)格指南。在你閱讀這個之前,你需要大致了解SCSS語法和KSS文檔。雖然我們通過KSS文檔把風(fēng)格移植到了SCSS上,但請務(wù)必立刻升級整個元素的CSS。不要混合少量SCSS和無格式的CSS。
編碼風(fēng)格:
1.用兩個空格的“soft-tabs”來縮進(jìn)
2.在屬性聲明的“:”后加上空格
3.在規(guī)則聲明后的“{”前加上空格
4.使用十六進(jìn)制顏色代碼#000,如果不使用RGBA
5.使用//來做注釋塊(而不是/**/)
6.文檔風(fēng)格與KSS相同
7.這里有個好的語法示例:
- // This is a good example!
- .styleguide-format {
- border: 1px solid #0f0;
- color: #000;
- background: rgba(0,0,0,0.5);
- }
SCSS 風(fēng)格:
任何會在多個文件中使用的$variable 或者 @mixin應(yīng)該放在globals/下。其他的應(yīng)該放在使用它的文件的頂部。
作為一個經(jīng)驗法則,不要使用超過3層的嵌套。如果你發(fā)現(xiàn)你將要使用超過三層,想想重新組織你的規(guī)則。
文件組織:
一般來說,CSS文件組織應(yīng)該想下面這樣:
styles
├── components
│ ├── comments.scss
│ └── listings.scss
├── globals
│ ├── browser_helpers.scss
│ ├── responsive_helpers.scss
│ ├── variables.scss
├── plugins
│ ├── jquery.fancybox-1.3.4.css
│ └── reset.scss
├── sections
│ ├── issues.scss
│ ├── profile.scss
└── shared
├── forms.scss
└── markdown.scss
使用Spockets來獲取文件。但是,你應(yīng)該明確地導(dǎo)入任何在特定的SCSS文件中不會產(chǎn)生樣式(globals/)的SCSS。下面是個好的例子:
- //= require_tree ./plugins
- //= require my_awesome_styles
- @import "../globals/basic";
- .rule { ... }
Pixels vs. Ems:
在font-size上使用px,因為它提供了在文字上的絕對控制。此外,更傾向于使用無單位的line-height,因為它不會繼承父元素的百分比值,而是基于字體大小的倍數(shù)。
Class的命名慣例:
不要在css文件中引用js-前綴的類名。js-只由js文件使用。在css和js共享的狀態(tài)規(guī)則使用is-前綴。
特異性(classes vs. ids):
在頁面中確定出現(xiàn)一次的元素應(yīng)該使用IDs.否則使用Class.在不確定時使用Class。
1.應(yīng)該使用ID的:header,footer,彈窗
2.不應(yīng)該使用ID的:導(dǎo)航,列表元素等
當(dāng)在給一個組件加樣式的時候,從元素+類名(更傾向于類名)開始,在默認(rèn)情況下更傾向于使用直接后代選擇器(>)。用盡可能少的特殊的。下面是個例子:
- <ul class="category-list">
- <li class="item">Category 1</li>
- <li class="item">Category 2</li>
- <li class="item">Category 3</li>
- </ul>
- ul.category-list {// element + class namespace
- &>li {// direct descendant selector > for list items
- list-style-type: disc;
- }
- a {// minimal specificity for all links
- color: #ff0000;
- }
- }
CSS特異性指南:
如果你必須使用一個id選擇器,確保在你的規(guī)則聲明中只有一個。像#header .search #quicksearch { … }這樣的被認(rèn)為是不好的。
當(dāng)在修改一個現(xiàn)有元素來特殊使用,試著使用類名。使用.listings-layout.listings-bigger而不是.listings-layout.bigger。想想ack/grep在你未來的代碼中。
像disabled, mousedown, danger, hover, selected,active這些類名應(yīng)該有一個類作為命名空間(button.selected是個好的例子)
實驗性功能:
我們想要內(nèi)部使用和實驗性功能。在編寫css的時候需要一些紀(jì)律因為現(xiàn)有的功能和實驗性功能的css將會被同時提供。始終牢記這些目標(biāo):
1.給新功能寫樣式的時候不要影響已有功能的樣式
2.當(dāng)實驗性功能不工作的時候可以很容易的移除
3.當(dāng)新功能上線的時候可以很容易移除舊的功能的css
4.在開發(fā)beta或?qū)嶒炐怨δ軙r,用-experimental變量替換根命名空間和棄用現(xiàn)有根節(jié)點(diǎn)。一般來說,最好重復(fù)樣式實驗塊而不是試圖和擴(kuò)展現(xiàn)有的樣式。
一個現(xiàn)有功能的:
- <div class="notifications">
- <ul class="navigation">
- <li><a href="#">Notifications</a></li>
- <li><a href="#">Messages</a></li>
- </ul>
- <div class="notifications-listing">
- <a href="#">dragon commented on Issue #551</a>
- <a href="#">mojombo commented on Issue #91</a>
- <a href="#">defunkt uploaded a new file to defunkt/resque</a>
- </div>
- </div>
- // Deprecated: Existing notifications + messages design. To be removed when
- // notifications-next ships.
- //
- // Styleguide 4.5.1
- .notifications {
- ul.navigation {
- float: left;
- width: 200px;
- background: #eee;
- }
- .notification-listing {
- &>a {
- display: block;
- font-weight: bold;
- }
- }
- }
在這里查看完整的版本:https://github.com/styleguide/css
相關(guān)文章
使用CSS和Bootstrap圖標(biāo)制作上下跳動的指示箭頭動畫效果
有時侯頁面很長,需要指示箭頭告訴用戶下面還有東西。下面腳本之家小編給大家?guī)砹耸褂肅SS和Bootstrap圖標(biāo)制作上下跳動的指示箭頭動畫效果,感興趣的朋友一起看看吧2018-06-04純CSS制作各種各樣的網(wǎng)頁圖標(biāo)(三角形、暫停按鈕、下載箭頭、加號等)
這篇文章主要介紹了純CSS制作各種各樣的網(wǎng)頁圖標(biāo)(三角形、暫停按鈕、下載箭頭、加號等)的相關(guān)資料,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過2018-03-27- css3功能非常強(qiáng)大,之前需要圖片完成的icon,現(xiàn)在我們只需要幾段css代碼就可以實現(xiàn)此功能。下面給大家分享純css制作的圓,橢圓,三角形箭頭圖標(biāo),非常使用,需要的朋友參考2016-03-30
- 本文為大家介紹下使用純css實現(xiàn)的交互小三角箭頭圖標(biāo),示例代碼如下,感興趣的朋友可以參考下2013-12-10
純CSS實現(xiàn)箭頭、氣泡讓提示功能具有三角形圖標(biāo)
準(zhǔn)備添加tooltips提示信息效果.實現(xiàn)很容易,但我想要讓提示功能具有三角形的指示圖標(biāo),本文兩種實現(xiàn)方式: 使用或不使用 before 和 :after 偽元素,示例如下,有此需求的朋2013-08-09CSS多級數(shù)字序號的目錄列表(2.2.1. 2.2.2 列表序號)
這篇文章主要介紹了CSS多級數(shù)字序號的目錄列表(2.2.1. 2.2.2 列表序號),通過css代碼定義將數(shù)字多級列表展示出來,,需要的朋友可以參考下2017-08-14完美解決調(diào)用上級目錄中的css樣式文件的路徑問題
調(diào)用上級目錄中的css樣式的路徑問題,為什么樣式文件沒有起到效果,想必有很多的朋友遇到過吧,下面為大家分享個不錯的解決方法,需要的朋友不要錯過2013-11-20CSS拾遺之箭頭,目錄,圖標(biāo)的實現(xiàn)代碼
這篇文章主要介紹了CSS拾遺之箭頭,目錄,圖標(biāo)的實現(xiàn)代碼,代碼簡單易懂,非常不錯,具有一定的參考借鑒價值,需要的朋友可以參考下2019-11-14