亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 開發 > CSS > 正文

CSS使用書寫規范

2020-03-24 16:42:25
字體:
來源:轉載
供稿:網友
可能不同團隊都有各自的規范,又或者很多人在寫 CSS 的時候還是想到什么就寫什么,不存在太多的約束。

我覺得 CSS 代碼規范還是有存在的必要的,尤其是在團隊配合,多人協作下,規范就顯得尤為重要。

本文的所列是實踐當中得出的一套比較不錯的 CSS 書寫規范,并不希望大家完全采用,而是可以結合自己的團隊需要,發展出一套適合自己的 CSS 代碼規范。

也希望可以有更多的建議,共同的完善。本規范也可以在我的 Github 上看到,歡迎留言或者提 PR。

編碼設置

采用 UTF-8 編碼,在 CSS 代碼頭部使用:

@charset utf-8 

注意,必須要定義在 CSS 文件所有字符的前面(包括編碼注釋),@charset 才會生效。

例如,下面的例子都會使得 @charset 失效:

/* 字符編碼 */@charset utf-8 html,body { height: 100%;@charset utf-8 

命名空間規范

布局:以 g 為命名空間,例如:.g-wrap 、.g-header、.g-content。

狀態:以 s 為命名空間,表示動態的、具有交互性質的狀態,例如:.s-current、s-selected。

工具:以 u 為命名空間,表示不耦合業務邏輯的、可復用的的工具,例如:u-clearfix、u-ellipsis。

組件:以 m 為命名空間,表示可復用、移植的組件模塊,例如:m-slider、m-dropMenu。

鉤子:以 j 為命名空間,表示特定給 JavaScript 調用的類名,例如:j-request、j-open。

命名空間思想

沒有選擇 BEM 這種命名過于嚴苛及樣式名過長過丑的規則,采取了一種比較折中的方案。

不建議使用下劃線 _ 進行連接

節省操作,輸入的時候少按一個 shift 鍵

能良好區分 JavaScript 變量命名

選擇器

當一個規則包含多個選擇器時,每個選擇器獨占一行。

、+、~、 選擇器的兩邊各保留一個空格。

.g-header .g-header-des,.g-content ~ .g-footer {}

規則聲明塊

當規則聲明塊中有多個樣式聲明時,每條樣式獨占一行。

在規則聲明塊的左大括號 { 前加一個空格。

在樣式屬性的冒號 : 后面加上一個空格,前面不加空格。

在每條樣式后面都以分號 ; 結尾。

規則聲明塊的右大括號 } 獨占一行。

每個規則聲明間用空行分隔。

所有最外層引號使用單引號 。

當一個屬性有多個屬性值時,以逗號 , 分隔屬性值,每個逗號后添加一個空格,當單個屬性值過長時,每個屬性值獨占一行。

完整示例如下:

.g-footer,.g-header { position: relative;.g-content { background: linear-gradient(135deg, deeppink 25%, transparent 25%) -50px 0, linear-gradient(225deg, deeppink 25%, transparent 25%) -50px 0, linear-gradient(315deg, deeppink 25%, transparent 25%), linear-gradient(45deg, deeppink 25%, transparent 25%);.g-content::before { content: }

數值與單位

當屬性值或顏色參數為 0 - 1 之間的數時,省略小數點前的 0 。

color: rgba(255, 255, 255, 0.5)

color: rgba(255, 255, 255, .5);

當長度值為 0 時省略單位。

margin: 0px auto

margin: 0 auto

十六進制的顏色屬性值使用小寫和盡量簡寫。

color: #ffcc00

color: #fc0

樣式屬性順序

單個樣式規則下的屬性在書寫時,應按功能進行分組,并以 Positioning Model Box Model Typographic Visual 的順序書寫,提高代碼的可讀性。

如果包含 content 屬性,應放在最前面;

Positioning Model 布局方式、位置,相關屬性包括:position / top / right / bottom / left / z-index / display / float / ...

Box Model 盒模型,相關屬性包括:width / height / padding / margin / border / overflow / ...

Typographic 文本排版,相關屬性包括:font / line-height / text-align / word-wrap / ...

Visual 視覺外觀,相關屬性包括:color / background / list-style / transform / animation / transition / ...

Positioning 處在第一位,因為他可以使一個元素脫離正常文本流,并且覆蓋盒模型相關的樣式。盒模型緊跟其后,因為他決定了一個組件的大小和位置。其他屬性只在組件內部起作用或者不會對前面兩種情況的結果產生影響,所以他們排在后面。

合理使用使用引號

在某些樣式中,會出現一些含有空格的關鍵字或者中文關鍵字。

font-family 內使用引號

當字體名字中間有空格,中文名字體及 Unicode 字符編碼表示的中文字體,為了保證兼容,都建議在字體兩端添加單引號或者雙引號:

body { font-family: Microsoft YaHei , 黑體-簡 , /5b8b/4f53 }
background-image 的 url 內使用引號

如果路徑里面有空格,舊版 IE 是無法識別的,會導致路徑失效,建議不管是否存在空格,都添加上單引號或者雙引號:

div { background-image: url( ... }

避免使用 !important

除去某些極特殊的情況,盡量不要不要使用 !important。

!important 的存在會給后期維護以及多人協作帶來噩夢般的影響。

當存在樣式覆蓋層疊時,如果你發現新定義的一個樣式無法覆蓋一個舊的樣式,只有加上 !important 才能生效時,是因為你新定義的選擇器的優先級不夠舊樣式選擇器的優先級高。所以,合理的書寫新樣式選擇器,是完全可以規避一些看似需要使用 !important 的情況的。

代碼注釋單行注釋

星號與內容之間必須保留一個空格。

/* 表格隔行變色 */
多行注釋

星號要一列對齊,星號與內容之間必須保留一個空格。

/** * Sometimes you need to include optional context for the entire component. Do that up here if it s important enough. */
規則聲明塊內注釋

使用 // 注釋,// 后面加上一個空格,注釋獨立一行。

.g-footer { border: 0; // ....}
文件注釋

文件頂部必須包含文件注釋,用 @name 標識文件說明。星號要一列對齊,星號與內容之間必須保留一個空格,標識符冒號與內容之間必須保留一個空格。

/** * @name: 文件名或模塊名 * @description: 文件或模塊描述 * @author: author-name(mail-name@domain.com) * author-name2(mail-name2@domain.com) * @update: 2015-04-29 00:02 */

@description為文件或模塊描述。

@update為可選項,建議每次改動都更新一下。

當該業務項目主要由固定的一個或多個人負責時,需要添加@author標識,一方面是尊重勞動成果,另一方面方便在需要時快速定位責任人。

SASS 使用建議嵌套層級規定

使用 SASS 、 LESS 等預處理器時,建議嵌套層級不超過 3 層。

組件/公用類的使用方法

組件/公用類使用 %placeholders 定義,使用 @extend 引用。如:

%clearfix { overflow: auto; zoom: 1;.g-header { @extend %clearfix;}
組件類的思考

使用 SASS ,經常會預先定義好一些常用公用組件類,譬如清除浮動,水平垂直居中,文字 ellipsis。又或者多個元素具有同樣的樣式,我們希望能夠少寫這部分代碼,公共部分抽離出來只寫一次,達到復用。

但是復用的方式在 SASS 中有多種,那么是使用單獨使用一個類定義,給需要的標簽添加,還是使用 @include 或者 @extend在定義的類中引入一個 @mixin,或者一個 @function 呢?

基于讓 CSS 更簡潔以及代碼的復用考慮,采用上面的使用 %placeholders 定義,使用 @extend 引用的方案。

%placeholders,只是一個占位符,只要不通過 @extend 調用,編譯后不會產生任何代碼量

使用 @extend 引用,則是因為每次調用相同的 %placeholders 時,編譯出來相同的 CSS 樣式會進行合并(反之,如果使用 @include 調用定義好的 @mixin,編譯出來相同的 CSS 樣式不會進行合并)

這里的組件類特指那些不會動態改變的 CSS 樣式,注意與那些可以通過傳參生成不同數值樣式的 @mixin 方法進行區分

盡量避免使用標簽名

使用 SASS ,或者說在 CSS 里也有這種困惑。

假設我們有如下 html 結構:

 div >

在給最里層的標簽命名書寫樣式的時候,我們有兩種選擇:

.g-content { .g-content-list { li {}

或者是

.g-content { .g-content-list { .item {}

也就是,編譯之后生成了下面這兩個,到底使用哪個好呢?

.g-content .g-content-list li { }

.g-content .g-content-list .item { }

基于 CSS 選擇器的解析規則(從右向左),建議使用上述第二種 .g-content .g-content-list .item { } ,避免使用通用標簽名作為選擇器的一環可以提高 CSS 匹配性能。

瀏覽器的排版引擎解析 CSS 是基于從右向左(right-to-left)的規則,這么做是為了使樣式規則能夠更快地與渲染樹上的節點匹配。

本規范也可以在我的 Github 上看到,歡迎留言或者提 PR。

到此本文結束,如果還有什么疑問或者建議,可以多多交流,原創文章,文筆有限,才疏學淺,文中若有不正之處,萬望告知。

以上就是CSS使用書寫規范的詳細內容,html教程

鄭重聲明:本文版權歸原作者所有,轉載文章僅為傳播更多信息之目的,如作者信息標記有誤,請第一時間聯系我們修改或刪除,多謝。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
国产精品久久视频| 日本精品视频在线播放| 最近2019年好看中文字幕视频| 亚洲欧美日韩另类| 国产精品91一区| 色综久久综合桃花网| 亚洲一区二区中文字幕| 精品国产一区二区三区在线观看| 美日韩在线视频| 欧美激情视频网址| 日韩成人av在线| 中文字幕9999| 久久精品亚洲热| 97精品久久久中文字幕免费| 国产成人一区三区| 久久久女女女女999久久| 精品久久久久久久久久国产| 欧美综合一区第一页| 欧美国产日韩在线| 久久全国免费视频| 日韩av在线最新| 国产精品91久久久久久| 成人精品一区二区三区电影黑人| 黑人巨大精品欧美一区免费视频| 在线播放国产一区中文字幕剧情欧美| 国产精品爽黄69天堂a| 亚洲国产美女精品久久久久∴| 亚洲免费人成在线视频观看| 久久精品成人一区二区三区| 亚洲精品一区二区三区不| 懂色av影视一区二区三区| 亚洲欧美三级在线| 亚洲视频999| 一二美女精品欧洲| 国产精品久久网| 91精品久久久久久久久久入口| 亚洲国产精品va在线| 国产精品极品在线| 欧美激情小视频| 亚洲精品久久久久国产| 亚洲福利视频免费观看| 黑人巨大精品欧美一区二区一视频| 亚洲精品不卡在线| 亚洲成人av在线| 亚洲国产97在线精品一区| 亚洲老板91色精品久久| 久久激情视频久久| 亚洲美女在线观看| 亚洲精品97久久| 91久久久久久久久久久| 亚洲精品福利资源站| 久久久久久国产三级电影| 精品国产一区av| 亚洲xxxx3d| 91精品久久久久久久久久久| 亚洲国产精品yw在线观看| 97人洗澡人人免费公开视频碰碰碰| 日韩亚洲精品视频| 国产精品成熟老女人| 国产精品吹潮在线观看| 亚洲三级黄色在线观看| 精品亚洲一区二区三区四区五区| 亚洲精品日产aⅴ| 91在线免费看网站| 美女国内精品自产拍在线播放| 亚洲丁香久久久| www.日韩免费| 菠萝蜜影院一区二区免费| 国产精品偷伦一区二区| 欧美亚洲午夜视频在线观看| 精品欧美国产一区二区三区| 亚洲精品98久久久久久中文字幕| 亚洲女人天堂成人av在线| 国产欧美一区二区三区久久人妖| 97久久伊人激情网| 国产精品青草久久久久福利99| 日本久久久久久| 欧美激情精品久久久久久黑人| 亚洲人永久免费| 成人性生交大片免费观看嘿嘿视频| 日韩美女在线观看一区| 超碰97人人做人人爱少妇| 欧美日本高清视频| 国产精品高清免费在线观看| 精品免费在线视频| 国产日韩欧美视频在线| 欧美一级电影免费在线观看| 欧美视频免费在线| 97国产在线观看| 亚洲www永久成人夜色| 精品夜色国产国偷在线| 亚洲精品影视在线观看| 日本最新高清不卡中文字幕| 一区二区三区国产在线观看| 这里精品视频免费| 亚洲最大av网| 久久成人这里只有精品| 亚洲天堂成人在线| 日韩欧美亚洲国产一区| 亚洲一区二区三区乱码aⅴ蜜桃女| 国产精品爱久久久久久久| 欧美日韩国产综合新一区| 日本精品一区二区三区在线播放视频| 日韩电影中文字幕一区| 精品久久久久久久久久国产| 国产精品爱啪在线线免费观看| 自拍视频国产精品| 久久久亚洲欧洲日产国码aⅴ| 美女扒开尿口让男人操亚洲视频网站| 在线亚洲欧美视频| 91精品国产综合久久久久久蜜臀| 91午夜在线播放| 国产精品视频xxx| 亚洲第一页自拍| 色婷婷综合久久久久| 国产成人拍精品视频午夜网站| 裸体女人亚洲精品一区| 久久国产天堂福利天堂| 日本精品视频在线观看| 狠狠爱在线视频一区| 国产欧美一区二区三区四区| 国产精品视频一区二区高潮| 国产精品一区久久| 欧美激情一级二级| 国产一区二区日韩精品欧美精品| 亚洲免费福利视频| 美女久久久久久久| 国产拍精品一二三| 国产精品一区二区三区成人| 伊人一区二区三区久久精品| 国产一区二区日韩精品欧美精品| 国产91ⅴ在线精品免费观看| 国产精品视频地址| 中文字幕在线日韩| 久久国产精品99国产精| 欧美在线一级va免费观看| 国产成人一区二区三区电影| 国产91精品久| 57pao成人永久免费视频| 亚洲欧美国产另类| 国模精品一区二区三区色天香| 久久久精品美女| 久久久av一区| 麻豆国产精品va在线观看不卡| 欧美成人国产va精品日本一级| 久久97久久97精品免视看| 日韩一区二区欧美| 疯狂蹂躏欧美一区二区精品| 国产精品成人国产乱一区| 国产精品国产三级国产aⅴ浪潮| 国产精品私拍pans大尺度在线| 国产日韩在线播放| 国产美女精品免费电影| 蜜月aⅴ免费一区二区三区| 国产亚洲美女精品久久久| 国产美女被下药99| 疯狂做受xxxx欧美肥白少妇| 疯狂欧美牲乱大交777| 国产日韩欧美夫妻视频在线观看| 欧美大肥婆大肥bbbbb| 日韩在线观看免费全| 久久久久国产精品一区| 日本亚洲欧洲色| 国产精品欧美一区二区三区奶水|