摘要:內容簡述關于,確實太繁雜了,內容多。寫好不易,基本上就這個調了。里面有許多屬性是可以繼承的,注意了,繼承一定是繼承父級元素的樣式在這里我就列出可以繼承的屬性,和不能繼承的屬性啦不可繼承的和。內聯元素可繼承。每個瀏覽器可能表現不一樣。
內容簡述
關于CSS,確實太繁雜了,內容多。寫好不易,基本上就這個調了。大家肯定聽過CSS奇淫技巧吧,關于這個我還沒有去深入了解,只是說普通的效果啥的,我基本沒問題了。我之前學CSS的時候也是感覺很心累,體會到了設計不當,對CSS屬性理解不深,繼而造成的牽一發而動全身的恐怖事件!!,太可怕了!!
只要我稍微改動一下,搞不好整個頁面都亂了,我之前在百度前端技術學院里做任務,讓我體會到了這一點,不過那是之前,后來寫的頁面多了,看看別人總結的經驗,慢慢的明白CSS應該如何寫了,如果你研究過Bootstrap的源碼,那么你的css肯定不差,后面我也會研究BT的源碼,到時候再更新吧。
這篇文章講的是CSS入門核心,你只要把這個學會了,自然CSS大體定格了,那么究竟講啥子呢? 我分成如下幾部分來講解:
tips: : 以下例子,均以Google瀏覽器為準
外補白(margin)
內補白(padding)
繼承特性(inherit)
標準文檔流(normal)
瀏覽器默認樣式(user agent stylesheet)
布局(layout)
定位(position)
樣式層疊(優先選擇模式)
外補白(margin)溫故而知新,可以為師矣
學習CSS,一定要會看盒子模型!! 看下面代碼:(以下代碼,瀏覽器默認樣式均沒有)
大家馬上就知道,頁面上該是啥樣了吧,但是肯定也會有你理解錯的地方啦,我們一起來看看
首先看整體效果:
嗯,和我想的一樣,再來看one的盒子模型:
可以看到,盒子one的四周都有20px的間隔,這個就是margin,也就是說,在我周圍20px范圍內是不允許有任何東西的!!
其實盒子two的盒子模型也是一樣的,所以我們很容易理解整體效果了。我們現在知道了
margin作用于兄弟元素,也就是說,同級別的,我的margin就是我的保護區,無論你是誰,你都不許靠近我的保護區,你只能在外面站
但是,下面這個你可能不知道了,可以看到,我們這個代碼,對one和two來說,有共同一個父級,我們看到,原來,左邊也有20px的距離呢!
看明白了吧,其實對于父元素而言,margin只會在水平方向起作用,豎直方向不起作用哦,所以,你是不是有經歷。改了子元素的margin-top,握草,整個布局都亂了,就是這個道理,父元素的頂部是緊貼子元素的。還有一點,body的盒子模型和container是一樣的
接著分析,看下面:
咦,怎么這里又頂部有了20px呢?不是說不起作用嗎?,其實,這個是html的盒子模型,下面會講到瀏覽器的默認樣式,html默認是沒有margin和padding的,也就是說,所有的內容,都是html的content區域
margin-top 的20px雖然沒有對父級元素起作用,但是它讓父級元素的父級元素body的 margin-top 為20px了,這個很重要.
margin的性質
有一個性質,那就是不疊加,取最大!還是上面那個例子,如果我設置container的margin-top為20px 是不會有任何變化的,為什么呢?因為container , body是父子關系,根據上面說的,他們兩頂部一直貼邊,你設置了container的margin-top為20px,本來就有20px的間距,你一樣的值,他當然不會變,如果你設置成30,那么就會往下移動10px了,這是特性。
內補白(padding)上面講了外補白,這里講內補白,其實內補白沒有什么難的,但是呢,很多人,也會掉坑里,平時寫CSS的時候不注意,容易掉坑,簡單的東西都要寫很久,就是因為沒有理解其特殊性。
內補白和外補白都需要理解盒子模型,那么在外補白我們已經見過盒子模型了,也有padding,margin,content,border呀,看一下我改動的代碼:
一下子貼了三張圖,padding是什么呢?說白了就是父與子的關系,只存在父子關系,所有設置了padding的元素,那么里面的東西,都只能在盒子padding里面寫入,這個屬性,一般用于,內容區域與邊框有一定的規律性間隔,用padding是最合適的了,注意哦,此時盒子one的總大小不是120 * 120了喲,而是140 * 140啦,這是個坑!! 總結一下:
padding 是針對父與子的,父元素設置了padding,子元素排布不在頂邊,而是與父元素邊框有距離了。
tips :這里要注意一點,就是你設置的width和高度是不包含padding的,所以一旦設置了width和height,你在設置padding的時候,一定要注意,有可能會打亂布局,我們應該加入box-sizing:border-box,這樣的話,width就包含padding了,仔細觀察盒模型
繼承特性(inherit)最后總結:標準盒模型,在盒子瀏覽器占據的總寬度是這樣計算的:border+padding+content (你設置的width,height是content的寬度)
在標準文檔流下,一個盒子占據瀏覽器的位置 :margin+border+padding+content ( 也就是說,這些區域不能有其他的元素占據 )
繼承特性,這個就不好講的很細,但是你想要好寫好CSS,不僅僅你要理解繼承 ,而且繼承還要用的妙,這樣在你寫CSS的過程中,可以精簡很多代碼。我現在看以前寫的CSS代碼,很垃圾,完全就是堆疊代碼,慘不忍睹。
繼承性是指指被包在內部的標簽將擁有外部標簽的樣式性,即子元素可以繼承父元素的屬性,例如下面的代碼,div中包含2個p標簽,1個span標簽,當給div設置字體顏色為紅色時,他的子標簽會繼承父元素的屬性,因而會顯示紅色。 在CSS中以text-、font-、line- 開頭的屬性都是可以繼承的。
CSS里面有許多屬性是可以繼承的,注意了,繼承一定是繼承父級元素的樣式!!
在這里我就列出可以繼承的屬性,和不能繼承的屬性啦
不可繼承的:display、margin、border、padding、background、height、min-height、max-height、width、min-width、max-width、overflow、position、left、right、top、bottom、z-index、float、clear、table-layout、vertical-align、page-break-after、page-bread-before和unicode-bidi。
所有元素可繼承:visibility和cursor。
內聯元素可繼承:letter-spacing、word-spacing、white-space、line-height、color、font、font-family、font-size、font-style、font-variant、font-weight、text-decoration、text-transform、direction。
終端塊狀元素可繼承:text-indent和text-align。
列表元素可繼承:list-style、list-style-type、list-style-position、list-style-image。
舉例:
a 標簽的字體顏色不能被繼承,例如將上面代碼的div標簽中代碼改為如下的代碼后,a標簽的字體顏色是不會改變的,通過頁面的F12可以查看得到,a標簽是有一個默認的 color: -webkit-link;字體顏色屬性,所以給父元素設置顏色是不能改變a標簽字體的顏色
h標簽字體的大小也是不能被繼承的,如下代碼給父元素在設置一個字體屬性20px,在div中添加一個h2標簽,在瀏覽器中可以發現h2標簽中的字體大小不會改變,因為h2標簽中也有一個默認的默認的font-size: 1.5em;字體大小屬性,
div 標簽的高度如果不設置由內容來決定(沒有內容高度為0),寬度默認由父元素繼承過來,下面的代碼就很好的演示了div的寬高,在每個div標簽后面添加了一個br標簽來強制換行,因為如果不使用br標簽來強制換行的話,div就會緊緊挨著一起,看不不出來div的高度,第一個div因為沒有內容,所以在瀏覽器上不顯示出來,而第二div里面添加了一句話,但是高度是由里面的內容撐出來的,第三個div里面也是一句話,并且在內容當中使用了一個br標簽來強制換行,這樣就會發現該div的高度會比第二div的高度要高,如果繼續向div標簽里面添加內容,高度也會隨之相應的變高。
a元素涉及到瀏覽器默認樣式,下面會講到默認樣式
標準文檔流(normal)塊級:占一行,不管有多大,我就占一行,占了一行,誰都不能再占我這一行,設置寬高起作用,占一行之后,不夠一行的位置,均是用margin替代,這一行不夠一整行的位置,我就另起一行。
行級:有多大,占多大,有空位子我就占,對此種標簽設置寬高不起作用,每個行級標簽默認有間隔,無法取消
規則:不管怎么占據,已經被占據的位置,一定不能再被占
瀏覽器默認樣式(user agent stylesheet)每個標簽都有默認的樣式,比如a標簽,默認藍色,下劃線,img標簽默認有邊框,p,ul li,dt,dd標簽默認有margin或者padding什么的,H1~H6標簽字體形狀和大小,都會有其默認的樣式
已下是HTML,和body的默認樣式
html width :瀏覽器寬度 height = 8px padding 0,margin 0 border 0 body height : 0 width:瀏覽器寬度 padding 0 margin 8px border 0
來看一段代碼:
可以看到,默認樣式原來是這樣的呢!
?
還有很多標簽的默認樣式,這里就不一一舉例,大家平時多看看,就記得住了。每個瀏覽器可能表現不一樣。
布局(layout)display : none | inline-block | inline | block |
visibility : visible | hidden | collapse
float: left | right
clear: left | right | both
overflow : hidden scorll | auto
float: 脫離標準文檔流 ,不按正常路線走, 我飄起來了,在空中呢,其他的元素當我不存在
設置浮動后,寬度不再默認父級元素的寬度(所有浮動的元素都是依次排,位置不夠往下走)
浮動之后,父級元素坍塌,你可以理解,我在空中,我在頂層,我是最外面的圖層,其他人占了我的位置,但是只顯示我,因為我是最外的圖層。
看這個布局,你就明白了
提出幾個問題:
div是快級元素,為什么會和盒子one站在一起呢?不是說塊級元素一定要占一行嗎?
two盒子沒有設置寬度,那么寬度就是100%了,也就是body的寬度,為什么沒有溢出body容器呢?
當你真正理解,我問的問題就都不是問題了!理解布局,什么頁面你都能搞定的!
clear:清除浮動,后面的元素對前面設置浮動的元素,不理睬,經常用在受浮動影響的元素(我們是不希望他受影響)
其實前面元素浮動了,對后面同級元素肯定會受影響的,同級元素當他不存在,肯定就從浮動的元素位置排布嘛,肯定有影響的,而且父元素高度坍塌,這個很影響布局
所以我們要考慮周全,深刻理解特性。
overflow : 超出隱藏 overflow-x/-y 在水平方向或者垂直方向隱藏
tips:overflow屬性,一般不用再比較高的祖先輩元素,其繼承特性很危險!!!
定位(position)人人都說定位難,定位是干啥用的呢?定位的用處就是,你要精確地控制元素的位置,比較特殊的位置,普通文檔流和布局都搞不定的時候,就要用到定位了
position: static(默認) | relative | absolute | fixed
元素
absolute: 絕對定位, 定位? 根據誰來定? (如果父級元素不存在定位元素 相對html定位)如果父級存在非static定位元素,則按照就近原則定位 , 一旦定位, 有了新的圖層,(脫離文檔流 ),圖層頂層
relative:相對定位,沒有脫離文檔流,占位置,相對自己原來的位置定位
fixed:固定定位,相對于瀏覽器窗口定位,不隨內容變化,一只固定在窗口位置
z-index: (int)number 改變圖層,用于定位元素(非static)
top,right,bottom,left : px percentage 只用于定位元素(非static定位),移動
定位就這么多內容了,這些應該是比較容易理解,可能應用上就懵逼了,哈哈,初學的話,都是這樣的
樣式層疊(優先選擇樣式)樣式有幾大引入方式
內嵌,內部樣式表,外部樣式表,默認樣式,繼承樣式
內嵌:就是寫在標簽里面的
內部樣式表:就是直接寫在頁面上的
外部樣式表:是一link形式引入的
默認樣式:就是瀏覽器給的也叫(user agent stylesheeet)
繼承樣式:繼承父元素的樣式
圖解:
記住規則:
其他屬性就近原則,內嵌>內部樣式表>外部樣式表
默認樣式>繼承樣式(這兩種樣式都是最低級的那種)
其他屬性,遇到難理解的在著重講一個,屬性太多,有的很簡單,沒有記錄的必要,不過我覺得針對移動端布局,這個還是很重要的,想看移動端布局CSS請看我這篇文章:[HTML+CSS入門之CSS3移動端布局]()
CSS參考手冊:推薦這個網站的不錯:CSS參考手冊_WEB前端開發參考手冊系列
文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規行為,您可以聯系管理員刪除。
轉載請注明本文地址:http://m.specialneedsforspecialkids.com/yun/112035.html
摘要:規定元素的上下文菜單。上下文菜單在用戶點擊元素時顯示。規定元素仍未或不再相關。規定是否對元素進行拼寫和語法檢查。規定元素的行內樣式。 一些說明 寫在前面:HTML和CSS,當你了解所有規則后,你應該多寫頁面并記錄你出現的問題,這才是學習HTML和CSS的最佳方法 這是我學習一段時間之后,再次回顧HTML,希望大家也對HTML有不一樣的認識 我把HTML標簽分成兩大類,重要的和不重要的,...
摘要:規定元素的上下文菜單。上下文菜單在用戶點擊元素時顯示。規定元素仍未或不再相關。規定是否對元素進行拼寫和語法檢查。規定元素的行內樣式。 一些說明 寫在前面:HTML和CSS,當你了解所有規則后,你應該多寫頁面并記錄你出現的問題,這才是學習HTML和CSS的最佳方法 這是我學習一段時間之后,再次回顧HTML,希望大家也對HTML有不一樣的認識 我把HTML標簽分成兩大類,重要的和不重要的,...
摘要:在我們深入研究這項新鮮的技術之前,讓我們先快速的復習原理的相關知識。同時,希望本文能對大家有所幫助。工欲善其事,必先利其器。 flex.css快速入門,極速布局 什么是flex.css? css3 flex 布局相信很多人已經聽說過甚至已經在開發中使用過它,但是我想我們都會有一個共同的經歷,面對它的各種版本,各種坑,傻傻的分不清楚,flex.css就是對flex布局的一種封裝,通過簡潔...
閱讀 2843·2023-04-26 02:23
閱讀 1587·2021-11-11 16:55
閱讀 3153·2021-10-19 11:47
閱讀 3366·2021-09-22 15:15
閱讀 1982·2019-08-30 15:55
閱讀 1042·2019-08-29 15:43
閱讀 1298·2019-08-29 13:16
閱讀 2200·2019-08-29 12:38