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

全面認識CSS中margin屬性用法

開發 前端
CSS中margin屬性在中文中我們翻譯成外邊距或者外補白(本文中引用外邊距)。他是元素盒模型(boxmodel)的基礎屬性,可以用來同時設置box的四邊外邊距,而其他的margin屬性只能設置其自各的外邊距。

本文向大家描述一下CSS中margin屬性的用法,margin屬性可以應用于幾乎所有的元素,除了表格顯示類型(不包括table-caption,tableandinline-table)的元素,而且垂直外邊距對非置換內聯元素(non-replacedinlineelement)不起作用。

CSS中margin屬性由淺入深詳解

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

一、margin的基本特性

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

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

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

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

二、margin的基本寫法

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

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

  margin的默認值為0,并且margin支持負值。

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

  1. margin:toprightbottomleft;  
  2.  

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

1.如果沒有left值,則使用right代替;

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

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

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

  1.如果margin只有三個值,按照值的順序為margin:toprightbottom;缺少了left,根據原則,則left的值有right來代替。

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

  2.如果margin只有兩個值,按照值的順序為margin:topright;缺少了bottom和left,根據原則left的值由right來代替,bottm的值由top來代替。

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

  3.如果margin只有一個值,按照值的順序為margin:top;缺少了bottom、left和right,根據原則left的值由right來代替,bottom的值由top來代替,right的值右top來代替,也就是說left的值也由top來代替。

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

三、margin的解析邏輯

  目前我們已經了解到了margin的基本特性和基本寫法,但對元素margin的基本解析邏輯還是很模糊,到底margin的top、right、bottom、left都是以什么為基準來促使boxmodel形成。為了形象,易懂的對margin的邏輯進行說明,下面講解的過程中,將引入W3C上沒有的參考線的說法。何謂參考線?參考線就是margin移動的基準點,此基準點相對于box是靜止的。而margin的數值,就是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數值為正值時候的情形,如果是負值則位移方向相反。

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

ExampleSourceCode

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

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

  1. margin:-10px20px-30px40px;  
  2.  

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

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

【編輯推薦】

  1. CSS中margin屬性解析邏輯
  2. CSS中margin屬性的基本特性和寫法
  3. CSS中font-size屬性值四大種類
  4. 解析四大CSS屬性值選擇器用法
  5. 專家推薦 DIV CSS表單布局的五個小技巧

  
 

 

責任編輯:佚名 來源: 52css.com
相關推薦

2010-08-24 13:14:36

CSSmargin

2010-08-25 15:49:04

CSSvertical-al

2010-08-27 11:10:30

CSSmargin

2010-08-25 10:21:49

CSSmargin

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-19 12:55:55

CSSMarginPadding

2010-09-03 10:31:31

CSSmargin

2010-09-08 14:00:08

marginCSS

2010-08-19 11:22:19

marginpadding

2010-09-02 15:54:54

CSS邊界疊加

2010-08-26 10:08:50

CSSmargin

2010-08-30 12:54:59

CSSmargin

2010-08-25 09:30:56

marginCSS
點贊
收藏

51CTO技術棧公眾號

在线免费一区| 蜜桃视频www网站在线观看| 国产精品对白交换视频| 福利电影导航| 欧美日韩aaaaaa| 亚洲第一二三四区| 97在线视频国产| 欧美涩涩网站| 成人午夜免费在线视频| 亚洲九九爱视频| 大地资源网3页在线观看| 日韩在线视频国产| 日产精品一区二区| 日韩欧美精品在线不卡 | 欧美三区四区| 欧美一级在线亚洲天堂| 亚洲欧美日本日韩| 99re在线视频免费观看| 日本道在线观看一区二区| 国产精品25p| 国产精品久久中文| 麻豆成人在线观看| 成人天堂入口网站| 欧美精品一区二区三区蜜臀| 一本久久青青| 一本一道久久a久久精品综合| 亚洲美女屁股眼交3| 这里有精品可以观看| 成人午夜黄色影院| 97se亚洲国产综合自在线不卡 | 国产裸体免费无遮挡| 在线免费观看日韩欧美| 亚洲人体在线| 日韩精品久久久毛片一区二区| 18成人在线观看| 伊人成综合网站| av日韩免费电影| 欧美国产乱子伦| 四虎影视国产在线视频| 国产高清在线不卡| av电影在线观看不卡| 欧美精品日韩少妇| 国产精品普通话| 国产视频不卡一区| 欧美xxxx做受欧美护士| 久久久久久国产精品免费免费| 《视频一区视频二区| 日本另类视频| 亚洲精品成人久久久998| 色综合天天做天天爱| 国产乱人伦丫前精品视频| 中文字幕精品在线播放| 欧美美女一区二区在线观看| 夜色77av精品影院| 丝袜老师办公室里做好紧好爽| 91精品国产欧美一区二区成人| 外国成人免费视频| 免费看的毛片| 51ⅴ精品国产91久久久久久| 91色乱码一区二区三区| 日韩在线伦理| 色一情一乱一伦一区二区三区丨| 色噜噜夜夜夜综合网| 日韩欧美中字| 天堂中文字幕| 91chinesevideo永久地址| 成人福利视频在线| 伊人久久av| 男女h黄动漫啪啪无遮挡软件| 日韩三级.com| 亚洲欧美日韩视频二区| 色影视在线观看| 国产精品9999久久久久仙踪林| 亚洲国产一区二区a毛片| 日韩大片在线免费观看| 超级碰碰视频| 情事1991在线| 亚洲精品亚洲人成人网| 伊人久久综合影院| 男男做性免费视频网| 国产精品成人久久久久| 亚洲一区二区三区国产| 日韩精品欧美| 日韩精品123| 成人精品一二区| 欧美中文字幕一区二区三区 | 国产对白在线| 久久久久国产精品www| 久久综合999| 涩涩屋成人免费视频软件| 日韩中文字幕免费在线| 精品国偷自产在线视频| www国产精品av| 2023国产精华国产精品| xxxx影院| 成人观看高清在线观看免费| 欧美性生交大片免费| 国产真实久久| 亚洲综合图区| 神马午夜伦理影院| 久久中文字幕国产| 国产精品美女视频| 欧美影院三区| 国自产拍在线网站网址视频| 久久久久一区二区| 日韩的一区二区| 99精品欧美一区二区蜜桃免费| 视频一区中文字幕精品| 一级日本免费的| 精品福利影视| 精品爽片免费看久久| www国产成人免费观看视频 深夜成人网 | 激情欧美一区| 羞羞电影在线观看www| 麻豆md0077饥渴少妇| 日韩中文在线不卡| 中文字幕av不卡| 日韩专区精品| 成人免费网址| 国产97在线 | 亚洲| 亚洲**2019国产| 全部免费毛片在线播放网站| 欧美精品99久久| 成人性生交xxxxx网站| 在线视频一区二区| 午夜精彩视频在线观看不卡| 亚洲免费婷婷| 另类图片第一页| 欧美sm精品调教视频| 欧美午夜精品久久久久久蜜| 68精品久久久久久欧美 | 国产视频网站一区二区三区| 蜜臀av一区二区| 午夜小视频福利在线观看| 国产aaa免费视频| 57pao国产精品一区| 欧美性生交片4| 成人深夜福利app| 精品日韩一区| 激情图片在线观看高清国产| 99蜜桃臀久久久欧美精品网站| 国产精品亚洲激情| 波多野结衣一区二区| 在线一级视频| 黑鬼大战白妞高潮喷白浆| 91天堂在线视频| 九九热精品视频国产| 日韩女优视频免费观看| 日本精品福利视频| 午夜在线免费视频| 欧美香蕉爽爽人人爽| 成人手机在线| 国产日韩av网站| 国产一区二区三区黄| 黄色三级中文字幕| 99久久精品情趣| 亚洲欧美国产日韩中文字幕| 国产精品网友自拍| 亚洲影院在线| av自拍一区| 在线中文字幕-区二区三区四区| 少妇人妻互换不带套| 精品国产一区二区三区四区精华| 久久大大胆人体| 欧美日韩免费一区二区三区| 国产欧美日韩视频一区二区| 全球最大av网站久久| 色135综合网| 国产蜜臀97一区二区三区| 国产精品色婷婷视频| www久久日com| 国产亚洲综合在线| 国产欧美一区二区三区另类精品| 阿v免费在线观看| 成人h动漫精品一区二区 | 日韩av在线免费观看不卡| 国产精品久久99久久| 国产深夜男女无套内射| 97国产视频| 丰满大乳少妇在线观看网站| 色在人av网站天堂精品| 伊人春色之综合网| 一区二区三区视频免费观看| 精品福利av| 99久久久久久| 亚洲成人三级在线| 国产精品爱久久久久久久| 久久国产精品久久精品国产| 成人在线免费观看av| 国产免费视频在线| 欧美日韩在线精品一区二区三区激情综合| 九九亚洲精品| 国产精品亚洲综合色区韩国| 亚洲偷熟乱区亚洲香蕉av| 国产高清视频在线| 午夜亚洲福利| 国产欧美一区二区精品秋霞影院| 亚洲第一福利一区| 欧美男同性恋视频网站| zzjj国产精品一区二区|