成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

CSS中margin屬性解析邏輯

開發 前端
CSS中屬性margin可以用來同時設置box的四邊外邊距,而其他的margin屬性只能設置其自各的外邊距,這里向大家描述一下CSS中margin屬性的解析邏輯。

本文和大家重點討論一下CSS中margin屬性的解析邏輯,margin在中文中我們翻譯成外邊距或者外補白(本文中引用外邊距)。它是元素盒模型(boxmodel)的基礎屬性,可以用來設置box的margin area。

CSS中margin屬性由淺入深詳解

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

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

CSS屬性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. <!DOCTYPEhtmlPUBLIC"-//W3C//DTDXHTML1.0Transitional//EN"  
  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|percentage</div> 
  13. </body> 
  14. </html> 
  15.  

 

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

ExampleSourceCode

  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-09-08 11:06:49

CSSpaddingmargin

2010-08-24 13:14:36

CSSmargin

2010-09-08 14:00:08

marginCSS

2010-09-03 10:43:05

CSSmargin

2010-08-27 11:10:30

CSSmargin

2010-08-19 11:22:19

marginpadding

2010-08-25 09:30:56

marginCSS

2010-08-25 10:21:49

CSSmargin

2010-08-30 12:54:59

CSSmargin

2010-08-26 10:08:50

CSSmargin

2010-08-25 08:57:33

marginpadding

2010-08-23 15:51:54

paddingmargin

2010-08-19 11:32:10

CSSpaddingmargin

2010-08-25 09:25:13

CSSmargin

2010-09-03 10:24:01

CSSmargin

2010-09-08 09:11:32

CSSmargin

2010-09-16 10:57:15

paddingmarginCSS

2010-08-25 11:05:03

CSSpaddingmargin

2010-08-25 09:48:25

CSSmargin

2010-08-25 10:38:35

margin-leftCSS
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 激情91| 久久精品国产v日韩v亚洲 | 久久久久无码国产精品一区 | 成人亚洲精品久久久久软件 | 欧美伦理一区 | 成人亚洲片| 成人久久久久 | av首页在线| 黄网站在线观看 | 日韩中文在线 | 毛片在线免费播放 | 美女久久久久久久 | 精品无码久久久久久久动漫 | 国产精品久久久久久久久久妇女 | 亚洲精品4| 日韩在线中文字幕 | 久久成人一区 | 欧美一级二级在线观看 | 男女视频91 | 日本超碰 | 欧美激情一区二区三区 | 精品99在线 | 日韩精品成人在线 | 神马久久久久久久久久 | 日本午夜在线视频 | 午夜大片 | 久久亚洲欧美日韩精品专区 | 欧美日韩1区2区3区 欧美久久一区 | 欧美日韩成人网 | 黄色片av| 狠狠婷婷综合久久久久久妖精 | 成年人黄色一级毛片 | 成人精品视频在线观看 | 亚洲精品久久区二区三区蜜桃臀 | 国产一区二区三区在线 | av天天干| av网站在线播放 | 亚洲视频免费观看 | 久久精品日产第一区二区三区 | 日本高清中文字幕 | 91久久国产综合久久 |