91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

css架構理念是什么

發布時間:2021-10-23 17:41:50 來源:億速云 閱讀:106 作者:iii 欄目:移動開發

本篇內容主要講解“css架構理念是什么”,感興趣的朋友不妨來看看。本文介紹的方法操作簡單快捷,實用性強。下面就讓小編來帶大家學習“css架構理念是什么”吧!

前言
做前端已有不短的時間了,在css這片領域越走越久、越走越遠,回過頭來看看,有很多技能知識掌握了就不會再忘了,比如無圖片實現三角形、ie下如何實現半透明效果等等;但有些東西卻需要在項目實戰中不斷地碰壁、總結,再碰壁、再總結,慢慢地去找到適合自己的方法,然后遵循這樣的方法,去開發,以收到事半功倍的效果。本篇文章就屬于后者,因為是站在整個css的大方向上,對于初學者或者項目實戰經驗不夠多的同學,建議有看不懂的地方不必太介意,可以跳過,也可以留言提問。經驗老道者也許也會些許吐槽,覺得跟您有出入,但是,我想說,css架構,因人而異、因項目大小而異,沒有最優,只有適合!

從語義化開始
看《css禪意花園》這類比較優秀的書籍就會發現,開篇一定會先提到html語義化。什么是html語義化?其實很簡單,html就那么幾個標簽,table標簽用做表格、p標簽用作文章段落、h系列標簽用作標題,不要整個html頁面除了a全部div+span。不得不說,xhtml在定義標簽上是有一定局限的,于是在html5里有增添了許多結構化標簽,從這方面來看,html語義化也是相當重要的,已經作為規范確立下來了。

為什么要做到html語義化?
嚴格來說,這是要歸到上個段落篇幅的,之所以單獨出來,是因為這跟本文的宗旨聯系緊密。但是,現在還是沒法說,不是賣關子,而是如果這個時候提出來,很難說清楚,大家看著也會云里霧里。如果您有耐心,繼續看下去,會理解的。

1.Css通用庫(global.css):該樣式表可以在所有的網站上使用,只要是個網站,就可以導入這個樣式表。它涉及css各個方面,比如css重置樣式、css的布局樣式、邊距、字體、字號、對齊方式,css通用庫是css樣式分離原則的直接體現(這里說的樣式分離和接下來要說的樣式組合原則是兩個較為復雜的概念,要很好地理解需要另外的篇幅來解釋,所幸這樣的文章還是有的,有時間可以看看前端牛人張鑫旭的博客文章:css樣式分離之再分離、css樣式合并與模塊化。我的css通用庫跟網上可見的大同小異,您如果有需要,可以直接在張鑫旭的相關文章中找到。下面附上我的css通用庫截圖:

css架構理念是什么

2.網站通用css(ktv_style.css):該樣式表遵循樣式組合原則,什么樣式可以放進這個樣式表?就是整個網站通用的模塊,比如網站通用文字和鏈接文字的顏色、頂級導航、邊框線、通用標題、網站底部、評論功能模塊等等,該樣式表牽一發動全身,改一個樣式,所有的頁面都隨之改動,所以,在改這個樣式的時候要慎重。
3.單頁面css(pages目錄下的所有樣式表):就像index.css這樣的首頁樣式表,每個頁面都獨立出一個,這樣做的目的是為了解決重命名引發的樣式沖突問題。這個問題會隨著項目越大、頁面結構越復雜而越來越凸顯。在頁面調用了不同的樣式表之后,那么即使html頁面使用了相同樣式命名,也不會出現沖突問題。
4.插件用到的css:該目錄下用的css基本上是引用的js插件的相關樣式表,之所以獨立為一個文件夾,是為了維護的方便。
以上4點大體上說清了我的css架構,每一點如果細細地講解下去,會有很多可講的東西,比如前面一兩點提到的樣式分離組合原則,如果本文沒法理解透徹,那么建議先去看相關文章。文章到此為止了嗎?答案是否定的。

模塊化你的樣式表
從這里開始,我們可以來談談為什么要做到html語義化了。
你是否有這樣的習慣,寫一個div,定義一個樣式名,往div里寫另一個標簽,再定義一個樣式名,然后到相應的css里書寫樣式?是的,誰不曾是呢!但是,我覺得這不是很好的做法。不好的地方有兩點:
1、你得花費不少的精力去考慮樣式的命名,命名是一件多么讓人惡心的事情;
2、拋棄這種寫法轉向模塊化處理樣式表,那么你會漸漸擁抱html語義化準則。這不是虛言,請往下繼續。

如何模塊化樣式表
模塊的含義:在我的理解里,模塊就是具有相同業務邏輯的、功能一樣或接近的,讓用戶看來這些元素就應該放在一起的一個集合。比如登錄后微博首頁的“可能感興趣的人”:

css架構理念是什么 

這樣的模塊包括:標題欄、簡單的列表。
微博對這個模塊的處理代碼,大家可以自己用firebug查看,比較復雜,如果是我來布局這個模塊的代碼,很簡單,我會這么寫:

代碼如下:


<div class=”friend_love”>
<h3>可能感興趣的人</h3>
<ul>
<li></li>
</ul>
<em>找人</em>
<span></span>
<a class=”more”>更多</a>
</div>


你看看是否可以理解我為何這么寫,每行代碼都是有考慮的,包括樣式命名。我并非說微博的前端人員不怎么樣,因為前端代碼的書寫要根據項目的方案、后端數據的呈現而做相應的調整,但是如果你僅僅是做前端方面的書寫,第一次書寫出的代碼就應該足夠簡單、語義明確。通過上面的html代碼,你可以布局自己的樣式:

代碼如下:


.friend_love h3{}
.friend_love ul{}
.friend_love em{}
.friend_love span{}
.friend_love .more{}


你還可以在樣式表中進行注釋:/*friend_love*/;
如果在另外一個頁面中也需要調用這樣一個模塊,就可以很好地拷貝,這么一個模塊,兩個樣式命名,你還在為命名發愁嗎?也許em這個元素只需要填寫float:left的樣式,那么恭喜你,你連寫這個樣式的必要都沒有了,直接在結構標簽中調用global.css里的樣式:<em class=”fl”></div>,為什么是fl,請參照global.css里左浮動樣式的定義。

到此,相信大家對“css架構理念是什么”有了更深的了解,不妨來實際操作一番吧!這里是億速云網站,更多相關內容可以進入相關頻道進行查詢,關注我們,繼續學習!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

css
AI

建始县| 南阳市| 天峻县| 西充县| 阳信县| 华安县| 桐庐县| 寿阳县| 棋牌| 罗甸县| 阜新市| 斗六市| 武乡县| 大渡口区| 安溪县| 桃园市| 河池市| 密山市| 长岭县| 车险| 宁河县| 孝感市| 香格里拉县| 砚山县| 晋城| 遂川县| 济源市| 资源县| 昌江| 沙田区| 蒲城县| 盐池县| 聂荣县| 阳江市| 进贤县| 沽源县| 资讯| 元谋县| 郴州市| 合肥市| 廊坊市|