欧美黑人激情性久久,一本色道久久综合无码人妻,欧美另类人妻制服丝袜,日韩精品一卡2卡3卡4卡新区乱码,欧洲熟妇性色黄在线观看免费,97夜夜澡人人爽人人喊中国片,77se77亚洲欧美在线,久久精品一区二区免费播放

                    由淺入深漫談margin屬性

                    blankzheng的blog: http://www.planabc.net/ margin在中文中我們翻譯成外邊距或者外補白(本文中引用外邊距)。他是元素盒模型(box model)的基礎屬性。 一、margin的基本特性 margin屬性包括margin-top,margin-right,margin-bottom,margin-left,margin,

                    blankzheng的blog:http://www.planabc.net/

                    由淺入深漫談margin屬性



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

                    一、margin的基本特性

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

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

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

                    引用:
                    “An element that is outside the scope of the CSS formatter, such as an image, embedded document, or applet”

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

                    margin始終是透明的。

                    二、margin的基本寫法

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

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

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

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

                    margin:top right bottom left;

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

                    margin-top:value;
                    margin-right:value;
                    margin-bottom:value;
                    margin-left:value;

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

                    引用:
                    1.如果沒有left值,則使用right代替;
                    2.如果沒有bottom值,則使用top代替;
                    3.如果沒有right值,則使用top值代替。

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

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

                    margin:10px 20px 30px;就等于margin:10px 20px 30px 20px;

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

                    margin:10px 20px;就等于margin:10px 20px 10px 20px;

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

                    margin:10px;就等于margin:10px 10px 10px 10px;

                    三、margin的解析邏輯

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

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

                    由淺入深漫談margin屬性



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

                    <!DOCTYPE html PUBLIC “-//W3C//DTD XHTML 1.0 Transitional//EN” “http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd”>
                    <html xmlns=”http://www.w3.org/1999/xhtml”>
                    <head>
                    <meta http-equiv=”Content-Type” content=”text/html; charset=utf-8″ />
                    <title>無標題文檔</title>
                    <style type=”text/css”>
                    div {width:200px; height:200px; background:#ccc;}
                    </style>
                    </head>

                    <body>
                    <div>外邊距的margin-width的值類型有:auto | length | percentage</div>
                    </body>
                    </html>

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

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

                    margin:-10px 20px -30px 40px;

                    這時候margin的解析邏輯是怎樣的呢?首先我們要搞清div的和周邊元素的關系,div沒有相連元素,而此時div的containing block是body產生的block box。則根據上面介紹的參考線原理,div的左外邊距以containing block的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最后的顯示大小到底是怎么樣的,或許有朋友也比較疑惑,我暫時用邏輯大小和物理大小來區分(其實上面已用到此概念),到底什么是邏輯大小,什么是物理大小呢?!具體可以看圖,物理大小指的是除去margin,也就是包含border以內的box大小,而邏輯大小,則是box通過margin解析規則解析后得到的大小(這或許可以解釋為什么IE5會錯誤解析盒模型),當邏輯大小小于物理大小時,則不會影響實際box的顯示,也就是說,此時顯示的是box的物理大小,而當邏輯大小大于物理大小時,則此時顯示邏輯大小。這僅對元素本身有效,對于其他相關元素,他們則只以margin的邏輯大小為準則,進行布局。

                    給TA打賞
                    共{{data.count}}人
                    人已打賞
                    html+css

                    CSS Hack匯總快查

                    2011-11-14 2:06:00

                    html+css

                    用CSS設計高用戶體驗的web文字大小

                    2011-11-14 2:12:00

                    0 條回復 A文章作者 M管理員
                      暫無討論,說說你的看法吧
                    ?
                    個人中心
                    購物車
                    優惠劵
                    有新私信 私信列表
                    搜索
                    主站蜘蛛池模板: 2020精品国产视| 久久99国内精品自在现线| 十八禁在线观看无遮挡| 亚洲18禁一区二区三区| 国产人妻人伦精品1国产丝袜| av无码av不卡一区二区| 少妇 人妻 欧美| 国产精品亚洲综合色区| 亚洲VA成无码人在线观看天堂| 亚洲国产欧美日本视频| 超清制服丝袜无码av福利网 | 亚洲欧美不卡高清在线| 久久精品中文字幕一区二区三区 | 色先锋玖玖av资源部| 欧美成人怡红院一区二区| 人妻中出受孕 中文字幕在线| 台湾无码av一区二区三区| 久久精品日日躁夜夜躁| 大肉大捧一进一出好爽app| 亚洲免费福利在线视频| 四虎在线成人免费观看| 亚洲日本中文字幕乱码在线电影| 最新高清中文字幕免费mv| 国产精品视频一区二区噜| 在线观看国产一区二区三区| 亚洲精品屋v一区二区| 韩国深夜福利视频在线观看| 亚洲精品亚洲人成在线| 国产精品极品在线拍| 国产成人精彩在线视频| 最近最新中文字幕高清免费| 精品婷婷色一区二区三区| 国产高清不卡视频| 自拍日韩亚洲一区在线| 国产真实露脸精彩对白| 久久视频在线视频精品| 国产一精品一av一免费| 深夜福利小视频在线观看 | 蜜臀色欲AV无码人妻| 亚洲国产av一区二区三区| 好爽好硬好深高潮视频456|