国产精品电影_久久视频免费_欧美日韩国产激情_成年人视频免费在线播放_日本久久亚洲电影_久久都是精品_66av99_九色精品美女在线_蜜臀a∨国产成人精品_冲田杏梨av在线_欧美精品在线一区二区三区_麻豆mv在线看

由淺入深學(xué)習(xí)CSS中margin屬性用法

開發(fā) 前端
你對CSS中margin屬性的用法是否了解,這里和大家分享一下,主要包括margin的基本特征和寫法,以及margin的解析邏輯等內(nèi)容。

margin在中文中我們翻譯成外邊距或者外補(bǔ)白,本文向大家介紹一下CSS中margin屬性的用法,希望對你的學(xué)習(xí)有所幫助。

CSS中margin屬性由淺入深詳解

margin在中文中我們翻譯成外邊距或者外補(bǔ)白(本文中引用外邊距)。他是元素盒模型(boxmodel)的基礎(chǔ)屬性。

一、margin的基本特性

  margin屬性包括margin-top,margin-right,margin-bottom,margin-left,margin,可以用來設(shè)置box的marginarea。屬性margin可以用來同時(shí)設(shè)置box的四邊外邊距,而其他的margin屬性只能設(shè)置其自各的外邊距。

  margin屬性可以應(yīng)用于幾乎所有的元素,除了表格顯示類型(不包括table-caption,tableandinline-table)的元素,而且垂直外邊距對非置換內(nèi)聯(lián)元素(non-replacedinlineelement)不起作用。

  或許有朋友對非置換元素(non-replacedelement)有點(diǎn)疑惑,稍微幫助大家理解一下。非置換元素,W3C中沒有給出明確的定義,但我們從字面可以理解到,非置換元素對應(yīng)著置換元素(replacedelement),也就是說我們搞懂了置換元素的含義,就懂了非置換元素。置換元素,W3C中給出了定義:

ExampleSourceCode

  1. “AnelementthatisoutsidethescopeoftheCSSformatter,  
  2. suchasanimage,embeddeddocument,orapplet”  

  從定義中我們可以理解到,置換元素(replacedelement)主要是指img,input,textarea,select,object等這類默認(rèn)就有CSS格式化外表范圍的元素。進(jìn)而可知,非置換元素(non-replacedelement)就是除了img,input,textarea,select,object等置換元素以外的元素。
  margin始終是透明的。

二、margin的基本寫法

  外邊距的margin-width的值類型有:auto|length|percentage

  percentage:百分比是由被應(yīng)用box的containingblock(注:一個(gè)元素的containingblock是該元素產(chǎn)生的box(es)在計(jì)算位置和大小時(shí)參考的一個(gè)矩形,詳細(xì)閱讀可看:《ContainingBlock》)的大小所決定。對于margin-top和margin-bottom也同樣成立。

  margin的默認(rèn)值為0,并且margin支持負(fù)值。

  上面我們曾提到屬性margin可以用來同時(shí)指定box的四邊外邊距。如果屬性margin有四個(gè)值,那么值將按照上-右-下-左的順序作用于四邊,即從元素的上邊開始,按照順時(shí)針的順序圍繞元素。表達(dá)式如下:

ExampleSourceCode

  1. margin:toprightbottomleft;  

 并且規(guī)范還提供了margin省略的數(shù)值寫法,基本原則如下:

1.如果沒有l(wèi)eft值,則使用right代替;

2.如果沒有bottom值,則使用top代替;

3.如果沒有right值,則使用top值代替。

  根據(jù)這些基本原則,我們可以有三種省略方式,但不管怎樣省略margin的數(shù)值都會大于等于一個(gè),而margin的默認(rèn)數(shù)值是從top開始至left結(jié)束,那么對于省略的具體情況,我們可以從left反推理回去。

  1.如果margin只有三個(gè)值,按照值的順序?yàn)閙argin:toprightbottom;缺少了left,根據(jù)原則,則left的值有right來代替。

margin:10px20px30px;就等于margin:10px20px30px20px;

  2.如果margin只有兩個(gè)值,按照值的順序?yàn)閙argin:topright;缺少了bottom和left,根據(jù)原則left的值由right來代替,bottm的值由top來代替。

margin:10px20px;就等于margin:10px20px10px20px;

  3.如果margin只有一個(gè)值,按照值的順序?yàn)閙argin:top;缺少了bottom、left和right,根據(jù)原則left的值由right來代替,bottom的值由top來代替,right的值右top來代替,也就是說left的值也由top來代替。

margin:10px;就等于margin:10px10px10px10px;#p#

三、margin的解析邏輯

  目前我們已經(jīng)了解到了margin的基本特性和基本寫法,但對元素margin的基本解析邏輯還是很模糊,到底margin的top、right、bottom、left都是以什么為基準(zhǔn)來促使boxmodel形成。為了形象,易懂的對margin的邏輯進(jìn)行說明,下面講解的過程中,將引入W3C上沒有的參考線的說法。何謂參考線?參考線就是margin移動(dòng)的基準(zhǔn)點(diǎn),此基準(zhǔn)點(diǎn)相對于box是靜止的。而margin的數(shù)值,就是box相對于參考線的位移量。

  在margin中top、right、bottom、left的參考線并不一致為一類,而是分為了兩類參考線,top和left的參考線屬于一類,right和bottom的參考線屬于另一類。那他們到底各以什么為參考線呢?top以containingblock的content上邊或者垂直上方相連元素margin的下邊為參考線垂直向下位移;left以containingblock的content左邊或者水平左方相連元素margin的右邊為參考線水平向右位移。right以元素本身的border右邊為參考線水平向右位移;bottom以元素本身的border下邊為參考線垂直向下位移。從上我們可以看到top和left都是以外元素為參考,而right和bottom以本元素為參考。上面的位移方向是指margin數(shù)值為正值時(shí)候的情形,如果是負(fù)值則位移方向相反。

  或許理論聽起來比較枯燥,我們舉例說明一下:

ExampleSourceCode

  1. http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd\"> 
  2. <htmlxmlnshtmlxmlns=\"http://www.w3.org/1999/xhtml\"> 
  3. <head> 
  4. <metahttp-equivmetahttp-equiv=\"Content-Type\"content=\"text/html;charset=utf-8\"/> 
  5. <title>無標(biāo)題文檔title> 
  6. <styletypestyletype=\"text/css\"> 
  7. div{width:200px;height:200px;background:#ccc;}  
  8. style> 
  9. head> 
  10. <body> 
  11. <div>外邊距的margin-width的值類型有:auto|length|percentagediv> 
  12. body> 
  13. html> 
  14.  

   如上代碼,很簡單,為了方便我們看到效果,我們給div設(shè)置了寬度和高度以及背景色。
  現(xiàn)在我們給div的樣式加上margin屬性,比如:

ExampleSourceCode

  1. margin:-10px20px-30px40px;  

  這時(shí)候margin的解析邏輯是怎樣的呢?

首先我們要搞清div的和周邊元素的關(guān)系,div沒有相連元素,而此時(shí)div的containingblock是body產(chǎn)生的blockbox。則根據(jù)上面介紹的參考線原理,div的左外邊距以containingblock的content左邊為參考線,及此時(shí)以body的content左邊為參考線進(jìn)行水平向右位移,位移的大小為40px,同理,上邊距以body的content上邊為參考線進(jìn)行垂直向上位移10px(負(fù)值和正值的方向相反),下邊距依照現(xiàn)在div的borer下邊(此時(shí)的div已經(jīng)經(jīng)過上邊距位移過了)垂直向上位移30px(此時(shí),margin不會改變box的border內(nèi)的物理大小,但會改變box的邏輯大小,即:以此box的margin的下邊為參考的元素,不是從box的物理位置開始的,而是從邏輯位置開始),右邊距依照現(xiàn)在div的borer右邊(此時(shí)的div已經(jīng)經(jīng)過左邊距位移過了)水平向右位移20px。或許有朋友問你分析的順序怎么和margin表達(dá)式中出現(xiàn)的順序不一樣?如果按照margin表達(dá)式中出現(xiàn)的順序來分析,結(jié)果是一樣的,只是為了更好的方便大家的理解而沒有按照表達(dá)式的順序來分析。

  用margin***的顯示大小到底是怎么樣的,或許有朋友也比較疑惑,我暫時(shí)用邏輯大小和物理大小來區(qū)分(其實(shí)上面已用到此概念),到底什么是邏輯大小,什么是物理大小呢?!具體可以看圖,物理大小指的是除去margin,也就是包含border以內(nèi)的box大小,而邏輯大小,則是box通過margin解析規(guī)則解析后得到的大小(這或許可以解釋為什么IE5會錯(cuò)誤解析盒模型),當(dāng)邏輯大小小于物理大小時(shí),則不會影響實(shí)際box的顯示,也就是說,此時(shí)顯示的是box的物理大小,而當(dāng)邏輯大小大于物理大小時(shí),則此時(shí)顯示邏輯大小。這僅對元素本身有效,對于其他相關(guān)元素,他們則只以margin的邏輯大小為準(zhǔn)則,進(jìn)行布局。

【編輯推薦】

  1. CSS Sprites工作原理及優(yōu)缺點(diǎn)
  2. CSS層疊與繼承用法手冊
  3. DIV布局規(guī)范中CSS類及id命名方式
  4. CSS網(wǎng)頁布局中id與class命名規(guī)則
  5. 將XHTML+CSS頁面轉(zhuǎn)換為打印機(jī)頁面技巧

 

責(zé)任編輯:佚名 來源: svn8.com
相關(guān)推薦

2010-08-25 09:37:39

margin

2010-08-24 13:14:36

CSSmargin

2010-09-03 10:43:05

CSSmargin

2010-08-25 10:21:49

CSSmargin

2010-08-19 12:55:55

CSSMarginPadding

2010-09-08 11:06:49

CSSpaddingmargin

2010-08-25 08:57:33

marginpadding

2010-08-25 09:25:13

CSSmargin

2010-08-19 11:32:10

CSSpaddingmargin

2010-08-23 15:51:54

paddingmargin

2010-08-25 11:13:49

CSS margin-righ

2010-09-06 11:02:59

CSSmargin

2010-08-31 08:51:58

marginCSS

2010-08-23 09:01:45

MarginPadding

2010-08-25 11:05:03

CSSpaddingmargin

2010-09-03 10:31:31

CSSmargin

2010-09-08 14:00:08

marginCSS

2010-08-19 11:22:19

marginpadding

2010-08-30 12:54:59

CSSmargin

2010-08-25 09:30:56

marginCSS
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號

精品av中文字幕在线毛片| 影音先锋亚洲电影| 日韩一区二区三区视频| 写真福利片hd在线观看| 久久综合久久综合九色| 在线观看17c| 成人羞羞网站入口| 91精品91久久久久久| 成人永久在线| 中文字幕精品网| 欧美少妇精品| 日韩激情av在线播放| www.久久ai| 91精品在线麻豆| 欧美成人三区| 欧美片网站yy| 黄色网页在线免费看| 欧美午夜宅男影院在线观看| 91佛爷在线| 综合自拍亚洲综合图不卡区| 久在线观看视频| 91网站视频在线观看| 黄色网页免费在线观看| 国产91高潮流白浆在线麻豆| 亚洲伊人婷婷| 国产一区二区三区免费播放 | 91精品论坛| 亚洲国产精品推荐| 偷拍中文亚洲欧美动漫| 在线观看亚洲区| 久久日本片精品aaaaa国产| 在线精品高清中文字幕| crdy在线观看欧美| 性欧美xxxx交| 久久亚洲国产| 精品乱码一区二区三区| 日本特黄久久久高潮| 日韩欧美一级在线| 国产免费观看久久| 在线视频三级| 日韩一区二区三区电影在线观看| 老司机深夜福利在线观看| 正在播放欧美一区| 美女午夜精品| 国产精品久久久久av福利动漫| 石原莉奈一区二区三区在线观看 | 亚洲影院在线| 日韩一级片一区二区| 久久丝袜美腿综合| 中文字幕视频在线| 日韩欧美国产麻豆| 日韩一区中文| 国产精品中文在线| 三级在线观看一区二区| 久久久噜噜噜www成人网| 亚洲国产日韩一区二区| 高h视频在线观看| 播播国产欧美激情| 中文字幕乱码亚洲无线精品一区 | 免费观看日韩毛片| 亚洲午夜成aⅴ人片| 麻豆网站视频在线观看| 中文字幕一区二区精品| 欧美日韩老妇| 男女啪啪的视频| 亚洲精品精品亚洲| 在线午夜影院| 欧美有码在线观看| 日韩精品每日更新| 国产天堂av| 在线免费看黄色| 欧美一区二区三区系列电影| 日韩精品三区| 国产国产精品人在线视| 美腿丝袜在线亚洲一区| 91精品免费看| 国产一区二区三区黄视频| 国产字幕中文| 亚洲第一区中文字幕| 欧美人与牛zoz0性行为| 视频在线观看成人| 一区二区三区在线高清| 美女福利一区二区三区| 国产日韩欧美视频| av一二三不卡影片| 久青青在线观看视频国产| 中文一区二区视频| 伊人蜜桃色噜噜激情综合| 午夜免费精品视频| 精品福利在线导航| 欧美色蜜桃97| 亚洲熟妇无码另类久久久| 欧美日韩国产高清一区二区三区 | 一级特黄性色生活片| 欧美日精品一区视频| av成人资源网| 最新av在线免费观看| 日韩欧美在线一区| 欧美日韩看看2015永久免费| 丰满女人性猛交| 欧美日韩亚洲国产综合| 日韩精品一区二区三区免费观看| 成人综合视频在线| 亚洲精品一区二区网址| 亚洲精一区二区三区| 亚洲japanese制服美女| 26uuu色噜噜精品一区二区| 在线免费观看a视频| 91免费看片在线| 最新中文字幕一区二区三区| 欧美日韩尤物久久| 日韩精品伦理第一区| 欧美图区在线视频| 亚洲自拍偷拍网| 中出福利视频| 日韩女优在线播放| 国产清纯白嫩初高生在线观看91 | 日本不卡不码高清免费观看| 深夜福利在线看| 国产欧美精品xxxx另类| 国产精品免费免费| 精品中文字幕一区二区三区四区| 在线电影看在线一区二区三区| 91精品国产aⅴ一区二区| 欧美午夜不卡| av一区在线观看| 国产乱码精品一区二区三区日韩精品| 岛国视频午夜一区免费在线观看| 精品亚洲成人| 性网站在线播放| 欧美性色黄大片手机版| 日韩.com| 最近最新mv在线观看免费高清| 国产成人久久久精品一区| 亚洲男女毛片无遮挡| 国产精品午夜一区二区三区| 欧美r片在线| 91免费观看网站| 欧美色男人天堂| 日本一不卡视频| 午夜精品成人av| 成人在线免费观看av| 高清欧美一区二区三区| 亚洲精品日韩综合观看成人91| 国产不卡一区| 午夜视频在线免费| 久久精品一二三区| 亚洲第一福利网| 成人av综合在线| 欧美韩一区二区| 九色视频在线观看免费播放| 清纯唯美一区二区三区| 亚洲人成网站色ww在线| 91麻豆国产自产在线观看| 免费看久久久| 亚洲一区二区三区精品中文字幕| 国产欧美日韩在线播放| 国产一区二区精品久久99| 欧美成人ⅴideosxxxxx| 尤物av无码色av无码| 韩国视频理论视频久久| 亚洲成人av一区二区| 影音先锋在线一区| 高清毛片在线观看| 激情五月亚洲色图| 91探花福利精品国产自产在线| 欧美一区二区三区电影| av中文字幕不卡| 日韩极品一区| 大桥未久在线视频| 1pon在线| 亚洲欧美日韩国产yyy| 久久全球大尺度高清视频| 色偷偷一区二区三区| 国内外成人在线| 猫咪成人在线观看| 色网站在线看| 日本成年人网址| 97操在线视频| 最新的欧美黄色| 精品久久久精品| 成人网男人的天堂| 国产精品成久久久久| 不卡一本毛片| 国产精品v日韩精品v在线观看| 国产一区二区三区高清视频| 久久久av电影| 欧美日韩综合一区| 久久久www成人免费毛片麻豆| 欧美喷水视频| 国产不卡精品| 麻豆av在线导航| 九七影院理论片| 中文网丁香综合网| 成人福利在线观看| 不卡毛片在线看| 精品久久久久久久久久久院品网 | 日本成人黄色网| 久久亚洲免费| 国产福利成人在线|