摘要:簡評是一種很耗時的操作,如果有良好的命名規(guī)范可以節(jié)約很多的時間。一些團(tuán)隊(duì)使用連字符分隔符,而其他團(tuán)隊(duì)則傾向于使用更加結(jié)構(gòu)化的稱為的命名規(guī)范。一般來說,命名規(guī)范有三個問題要解決能夠通過名字就能清楚選擇器的功能。
簡評:Debug CSS 是一種很耗時的操作,如果有良好的命名規(guī)范可以節(jié)約很多的 Debug 時間。
使用連字符("-")分隔字符串
你可能習(xí)慣了在 Javascript 中使用小駝峰的命名方式:
var redBox = document.getElementById("...")
但是在 CSS 中不建議使用這種命名方式:
.redBox { border:1px純紅色; }
而應(yīng)該使用這種:
.red-box { border:1px純紅色; }
這是一個標(biāo)準(zhǔn)的 CSS 命名規(guī)則,有更好的可讀性。
此外,他和 CSS 屬性名稱一致。
//正確 .some-class { font-weight:10em } //錯了 .some-class { fontWeight:10em }
BEM 命名規(guī)范
團(tuán)隊(duì)有不同的方法來編寫 CSS 選擇器。一些團(tuán)隊(duì)使用連字符分隔符,而其他團(tuán)隊(duì)則傾向于使用更加結(jié)構(gòu)化的稱為 BEM 的命名規(guī)范。
一般來說,CSS 命名規(guī)范有三個問題要解決:
能夠通過名字就能清楚選擇器的功能。
能夠看出選擇器在哪里可以使用。
能夠看出 class 之間的關(guān)系。
你有沒有見過這樣寫的類名:
.nav--secondary { ... } .nav__header { ... }
這就是 BEM 命名規(guī)則。
B 代表塊(Block)
BEM 試圖將整個用戶界面分成可重用獨(dú)立的塊(Block,注意這里的 Block 并非指 inline-block),一個 header 是一個 block,header 里面嵌套的元素(logo、input、menu)也可以是 block 。
舉個例子下面的圖片:
這是一個火柴人(我們可以把它看做一個 Block),按照之前的說法,這個組件的命名我們可以設(shè)為 stick-man。
主鍵的樣式應(yīng)該如下所示:
.stick-man { }
E 代表元素
Block 中一般會有多個元素,舉個例子:火柴人有一個 head,兩個 arms 和 feets
head、feet、和 arms 是該組件中的所有元素。使用 BEM 命名規(guī)則,通過雙下劃線連接塊(Block)和元素(Elements)方式來命名。
.stick-man__head { } .stick-man__arms { } .stick-man__feet { }
M 代表修飾符
BEM 中 M 代表修飾,可以對塊(Block)或元素(Element)進(jìn)行修飾(外觀或行為的調(diào)整),我們可以調(diào)整我們的火柴人生成藍(lán)色火柴人和紅色火柴人(實(shí)際上我們可能需要一個藍(lán)色按鈕和一個紅色按鈕)。
使用 BEM 的命名規(guī)則我們使用雙連接符來命名("--")
例如:
.stick-man--blue { } .stick-man--red { }
修飾符也可用于元素(element),例如我們只想調(diào)整火柴人的頭部大小。我們可以這樣命名
.stick-man__head--small { } .stick-man__head--big { }
以上就是 BEM 的命名方式,這種命名方式雖然有點(diǎn)啰嗦但是在復(fù)雜的工程中可以很好的理清各部分之間的關(guān)系,如果只是簡單的工程直接使用分隔符命名就行了。
在 JavaScript 中用到的 CSS 類名應(yīng)該如何命名
當(dāng)你看到這個篇文章開始著手重構(gòu)自己的項(xiàng)目。
你將原來的代碼:
改成了:
這看著很棒,但是你忘了你在某個地方(JavaScript)用到了這個類名:
//the Javasript code const nav = document.querySelector(".siteNavigation")
這個時候 nav 將會得到 null。
為了防止這種情況,我們可以使用如下的命名來提醒我們。
使用 "js-*" 來命名
我們可以使用 js- 來命名我們的類:
在 JavaScript 代碼我們使用 js-site-navigation 來獲取該 DOM:
//the Javasript code const nav = document.querySelector(".js-site-navigation")
現(xiàn)在我們只要一看到 js-site-navigation 就會想到,在某個 JavaScript 代碼中使用該類名獲取 DOM 對象。
英文原文: CSS Naming Conventions that Will Save You Hours of Debugging
文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請注明本文地址:http://m.specialneedsforspecialkids.com/yun/115694.html
摘要:在這篇譯什么是我們?yōu)槭裁葱枰麄兊慕Y(jié)尾處,明確指出不需要,那么到底是什么呢下面我將把官網(wǎng)的教程翻譯出來,帶領(lǐng)大家搞清楚前端領(lǐng)域的到底是什么。命名在計算機(jī)科學(xué)領(lǐng)域,只有個非常難解決的問題一個是緩存失效,而另一個則是命名。 在這篇【譯】什么是CSS Modules ?我們?yōu)槭裁葱枰麄儯康慕Y(jié)尾處,明確指出CSS Modules不需要BEM,那么BEM到底是什么呢? 下面我將把BEM官網(wǎng)的教...
H5編輯器介紹 H5DS (HTML5 Design software) 這是一款基于WEB的 H5制作工具。讓不會寫代碼的人也能輕松快速上手制作H5頁面,界面如下 showImg(https://segmentfault.com/img/bVUC2L?w=1147&h=643); 制作流程 注冊 -> 登錄 -> 新建H5 -> 編輯H5 (添加頁面,添加圖層,拖動設(shè)置參數(shù)) -> 預(yù)覽/保存/...
H5編輯器介紹 H5DS (HTML5 Design software) 這是一款基于WEB的 H5制作工具。讓不會寫代碼的人也能輕松快速上手制作H5頁面,界面如下 showImg(https://segmentfault.com/img/bVUC2L?w=1147&h=643); 制作流程 注冊 -> 登錄 -> 新建H5 -> 編輯H5 (添加頁面,添加圖層,拖動設(shè)置參數(shù)) -> 預(yù)覽/保存/...
摘要:就會給起名表示求和函數(shù),漸漸地知道最好用英語給變量或者是函數(shù)名起名字,盡管有時候英語不好,那就翻翻有道吧。所以有一段時間的命名是很長的兩三個單詞的駝峰法命名。 什么鬼,又不知道怎么命名class了直接進(jìn)入正文 記得大一學(xué)C語言的時候,那個時候根本沒把這當(dāng)回事吧。所謂的混沌階段變量名,函數(shù)名,隨意吧,那個時候?qū)懞唵蔚豤程序,就好像寫著玩,就算復(fù)雜點(diǎn)得也不過一二百行,所以變量名什么的,可能...
閱讀 1546·2023-04-26 00:20
閱讀 1135·2023-04-25 21:49
閱讀 818·2021-09-22 15:52
閱讀 592·2021-09-07 10:16
閱讀 982·2021-08-18 10:22
閱讀 2679·2019-08-30 14:07
閱讀 2250·2019-08-30 14:00
閱讀 2667·2019-08-30 13:00