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

由淺入深學習margin屬性用法和特征

開發 前端
本文和大家由淺入深學習一下margin屬性的基本特征,margin在中文中我們翻譯成外邊距或者外補白(本文中引用外邊距),他是元素盒模型(boxmodel)的基礎屬性。

你對margin屬性的用法和特征是否了解,這里和大家分享一下,屬性margin可以用來同時設置box的四邊外邊距,而其他的margin屬性只能設置其自各的外邊距。

由淺入深漫談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等置換元素以外的元素。

margin始終是透明的。#p#

二、margin的基本寫法

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

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

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

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

margin:toprightbottomleft;
四個數值中間以空格分隔。效果等同于:

  1. margin-top:value;  
  2. margin-right:value;  
  3. margin-bottom:value;  
  4. margin-left:value;  
  5.  

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

◆引用:

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數值為正值時候的情形,如果是負值則位移方向相反。

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

  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.  
  12. <body> 
  13. <div>外邊距的margin-width的值類型有:auto|length|percentagediv> 
  14. body> 
  15. html> 
  16.  

 

如上代碼,很簡單,為了方便我們看到效果,我們給div設置了寬度和高度以及背景色。

現在我們給div的樣式加上margin屬性,比如:

margin:-10px20px-30px40px;

◆這時候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的邏輯大小,而box實際顯示的高度等于box的物理大小,這說明box實際顯示的大小可能是box的邏輯大小,也可能是box的物理大小,規則到底是怎樣的——

box的實際大小=box的物理大小+正的margin

這僅對元素本身有效,對于其后面的相關元素,他們則只以margin的邏輯大小為準則,進行布局。

有朋友反應,聽得很迷糊,越看越不懂,如果你對具體的理解過程不感興趣的話,那記住下面我總結的結論就可以了,XD

結論:

box***的顯示大小等于box的border及border內的大小加上正的margin值。而負的margin值不會影響box的實際大小,如果是負的top或left值會引起box的向上或向左位置移動,如果是bottom或right只會影響下面box的顯示的參考線。

【編輯推薦】

  1. CSS margin 屬性定義和用法
  2. IE6.0對padding的解讀分析
  3. DIV+CSS網頁錯位診斷和解決方法
  4. CSS中margin屬性用法淺析
  5. 技術分享 如何使用CSS控制超鏈接文字樣式

 

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

2010-08-27 11:10:30

CSSmargin

2010-08-25 09:43:42

margin

2010-08-25 09:25:13

CSSmargin

2010-08-19 12:55:55

CSSMarginPadding

2010-08-23 09:01:45

MarginPadding

2010-08-25 10:05:03

margin-top

2010-08-25 10:21:49

CSSmargin

2010-08-25 08:57:33

marginpadding

2010-08-23 15:51:54

paddingmargin

2010-08-19 11:32:10

CSSpaddingmargin

2010-08-24 13:14:36

CSSmargin

2010-08-25 11:13:49

CSS margin-righ

2010-09-03 10:43:05

CSSmargin

2010-08-31 08:51:58

marginCSS

2010-09-06 11:02:59

CSSmargin

2010-09-08 11:06:49

CSSpaddingmargin

2010-08-23 15:40:18

MarginBorderPadding

2010-08-25 11:05:03

CSSpaddingmargin

2010-08-25 09:48:25

CSSmargin

2010-08-19 11:22:19

marginpadding
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 91视视频在线观看入口直接观看 | 免费a级毛片在线播放 | 91在线视频一区 | 丝袜美腿一区二区三区 | 国产传媒 | 日韩免费一区 | 久久久久久免费精品一区二区三区 | 婷婷精品| 一本在线 | 久久一二 | 亚洲国产伊人 | 国产ts人妖系列高潮 | 国产污视频在线 | 天天综合永久 | 精品日韩电影 | 国产高清自拍视频在线观看 | 欧美精品欧美精品系列 | 亚洲97| 伊人网影院 | 精品国产乱码久久久久久蜜柚 | 国产亚洲欧美在线 | 国产区精品 | 日韩成人国产 | 欧美一区二区三区日韩 | 精品一区二区观看 | 我想看国产一级毛片 | 91精品国产综合久久久动漫日韩 | 我爱操| 中文无码日韩欧 | 国内自拍偷拍 | 国产精品成人在线播放 | a级免费视频 | 日韩av免费看 | 亚洲视频国产 | 精品综合 | 日韩欧美三级 | 久久成人一区 | 日韩一区精品 | 91精品成人久久 | 日韩成人av在线 | 亚洲影音|