摘要:扒一扒淘票票界面淘票票界面寫的挺美觀的,但是最近看了看淘票票的命名方式,覺得稍有不妥。命名與頁面內容掛鉤,代碼復用性低。
BEM解析
BEM是一套CSS國際命名規范,是一個非常有用的功能強大且簡單的命名約定,它能使前端代碼更易讀,易于理解易于擴展。BEM是塊(block)、元素(element)、修飾符(modifier)的縮寫。
B:Block是塊,一個獨立的組件,將所有東西都劃分成一個組件
E:Element是塊中的子節點,為了表明子節點屬于哪個塊,寫法是 block__element
M:Modifier聲明某個節點的修飾狀態
我們以一個搜索框來簡單說明上述三個東西的用法:
這個搜索框就可以看作一個塊Block,這個塊里由兩個子節點,一個是輸入區域input,還有一個是查詢按鈕button。
對于這個塊的命名,按照BEM法則,我們可以寫成以下這樣:
將整體的搜索框命名為site-search作為一個模塊,模塊下的兩個子節點就在后面加上兩根下劃線,加上自己的名字 input 和 button,這樣的命名方式,即使我們沒有看到網頁內容,只看了CSS樣式名字,也能感受到頁面結構和頁面元素之間的關系。
如果要說明按鈕button是灰色的,我們還可以加上修飾的類名modifier,比如可以是site-search__button--gray。
上圖就說明能將某個元素進行模塊化,里面能夠包含多個元素,這樣的命名規范能夠更好的說明元素之間的關系。
你是否遇到過寫CSS樣式名抓耳撓腮的時候?你是否遇到過團隊合作時看不清別人代碼,只能無奈的說“這個CSS重寫一遍比修改老文件快”?
BEM命名法則給我們帶來了以下的便利:
BEM命名法則給我們提供了一個很好的模板,在命名中就能體現各個元素之間的關系,CSS的命名更加語義化,元素更易讀懂。
而且獨一無二的命名方式,使得代碼能夠得到更好的復用,就不用在寫樣式名的時候小心翼翼,生怕和前后文的樣式名重名,導致元素組件的樣式被覆蓋。
剛接觸BEM命名方式可能會覺得一個元素的類名這么冗長,比較難看,可就是這種冗長的命名,極大的減少了類名重復的可能性。
BEM官網說明這種命名規范最關鍵的特征就是:
扒一扒淘票票界面BEM的關鍵特征就是塊的獨立性。按照CSS的建議,可以在網頁上的任何位置放置一個塊,并確保不會受到周圍環境的影響。而且,如果您最近需要將另一個塊嵌套到當前塊中,則它們的完全兼容性將得到保證。換句話說,在維護Web應用程序時,您可以在整個頁面上移動塊,添加其他項并將其組合起來。
淘票票界面寫的挺美觀的,但是最近看了看淘票票的CSS命名方式,覺得稍有不妥。
比如淘票票最頂部的索引橫條。
以下是淘票票對于頂部導航欄的CSS命名,為了讓大家更好看清頁面結構,我對頁面元素進行了簡單的處理,以及添加了幾行注釋:
這里存在兩個較為嚴重的問題:
1、頁面結構不清晰。從CSS的命名方式上來看,很難看得出上面這些類是放在一塊的,同一模塊中的內容缺少聯系。
2、CSS命名與頁面內容掛鉤,代碼復用性低。觀察以上的命名方式,比如cityWrap、entrance、phone之類的,命名方式都和頁面內容掛鉤,這種命名方式缺點就是不能挪到其他地方進行復用。因為其他頁面可能沒有城市、入口、手機這些內容。或者,萬一頁面元素要進行更改,比如把城市(cityWrap)改成國家(country),為了保持CSS和頁面內容的統一性,就要更改所有的CSS樣式,給代碼的維護增加了不小的困難。
我的更改建議是使用BEM命名法則,將頁面元素模塊化.
整個導航欄作為一個模塊,模塊可以分為典型的三層:head、body、footer,分別存放logo、導航條內容、尾部的其他功能:
導航條看成一整個模塊Block,該模塊有三個子節點元素Elemet,經過這種命名方式,即使不看頁面元素,只看CSS元素的類名,是不是也能猜出大概結構來呢?而且不使用頁面的內容作為命名方式,這樣的話,以后有類似結構的頁面,也能直接復用這一套CSS樣式,同時,清晰的命名方式也讓頁面維護變得更為簡單。
掘金文章地址:https://juejin.im/post/5a1399...
文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規行為,您可以聯系管理員刪除。
轉載請注明本文地址:http://m.specialneedsforspecialkids.com/yun/112741.html
摘要:注一篇去年的舊文,發現沒在知乎發過,過來補個檔。于是就有了我們這個小項目電影票比價網在我們這個網頁上,會展示出當前熱映的電影。涉及到模塊主要是用來匹配不同渠道的影院信息代碼結構項目主要有三塊使用豆瓣每日更新上映的影片列表。 注:一篇去年的舊文,發現沒在知乎發過,過來補個檔。有個小問題是項目中淘票票的網頁反爬提升且變動較多,目前暫不可用了。 時常有同學會問我類似的問題:我已經學完了 Py...
摘要:有了之前的簡述的使用,大致了解了的使用。今天我們就來扒一扒的源碼。好了,整個和就關聯在一起了。注下篇文章我們再來扒一扒源碼當把事件廣播出去后,我們就開始執行該事件的各個監聽了。 有了之前的《簡述 Laravel Model Events 的使用》https://mp.weixin.qq.com/s/XrhDq1S5RC9UdeULVVksoA,大致了解了 Event 的使用。 今天我們...
摘要:年成立的為互聯網提供真正的隨機數。在年,隨機數市場發生了一個巨大的變化,在其芯片組上集成了芯片級的隨機數生成器。 作者:Alon Zakai 編譯:胡子大哈 翻譯原文:http://huziketang.com/blog/posts/detail?postId=58cfc3dda6d8a07e449fdd29 英文原文:A Brief History of Random Number...
閱讀 1163·2023-04-25 17:28
閱讀 3567·2021-10-14 09:43
閱讀 3973·2021-10-09 10:02
閱讀 1949·2019-08-30 14:04
閱讀 3137·2019-08-30 13:09
閱讀 3277·2019-08-30 12:53
閱讀 2906·2019-08-29 17:11
閱讀 1828·2019-08-29 16:58