成人无码视频,亚洲精品久久久久av无码,午夜精品久久久久久毛片,亚洲 中文字幕 日韩 无码

資訊專欄INFORMATION COLUMN

用Margin還是用Padding?(轉(zhuǎn)載)

cnTomato / 649人閱讀

摘要:個(gè)人認(rèn)為是用來隔開元素與元素的間距是用來隔開元素與內(nèi)容的間隔。舉個(gè)例子吧用還是用我是,我只是想和我的父元素隔開點(diǎn)距離,這樣看起來舒服。

轉(zhuǎn)載出自?海玉的博客?
本文地址:?http://www.hicss.net/use-margin-or-padding/

用margin還是用padding這個(gè)問題是每個(gè)學(xué)習(xí)CSS進(jìn)階時(shí)的必經(jīng)之路。

CSS邊距屬性定義元素周圍的空間。通過使用多帶帶的屬性,可以對(duì)上、右、下、左的外邊距進(jìn)行設(shè)置。也可以使用簡(jiǎn)寫的外邊距屬性同時(shí)改變所有的外邊距。——W3School
邊界(margin):元素周圍生成額外的空白區(qū)?!翱瞻讌^(qū)”通常是指其他元素不能出現(xiàn)且父元素背景可見的區(qū)域?!狢SS權(quán)威指南

padding稱呼為內(nèi)邊距,其判斷的依據(jù)即邊框離內(nèi)容正文的距離,而我喜歡CSS權(quán)威指南解釋的“補(bǔ)白”(或者叫“留白”),因?yàn)樗苄蜗?。補(bǔ)白(padding):補(bǔ)白位于元素框的邊界與內(nèi)容區(qū)之間。很自然,用于影響這個(gè)區(qū)域的屬性是padding?!狢SS權(quán)威指南

關(guān)于什么時(shí)候用margin什么時(shí)候用padding,網(wǎng)上有許許多多的討論,大多數(shù)似乎討論到點(diǎn)上面,卻又有些隔靴搔癢的感覺,總是答不到點(diǎn)上。而且margin和padding在許多地方往往效果都是一模一樣,而且你也不能說這個(gè)一定得用margin那個(gè)一定要用padding,因?yàn)閷?shí)際的效果都一樣,你說margin用起來好他說padding用起來會(huì)更好,但往往爭(zhēng)論無果。根據(jù)網(wǎng)上的總結(jié)歸納大致發(fā)現(xiàn)這幾條還是比較靠譜的:

何時(shí)應(yīng)當(dāng)使用margin:
需要在border外側(cè)添加空白時(shí)。
空白處不需要背景(色)時(shí)。
上下相連的兩個(gè)盒子之間的空白,需要相互抵消時(shí)。如15px + 20px的margin,將得到20px的空白。

何時(shí)應(yīng)當(dāng)時(shí)用padding:
需要在border內(nèi)測(cè)添加空白時(shí)。
空白處需要背景(色)時(shí)。
上下相連的兩個(gè)盒子之間的空白,希望等于兩者之和時(shí)。如15px + 20px的padding,將得到35px的空白。

個(gè)人認(rèn)為:margin是用來隔開元素與元素的間距;padding是用來隔開元素與內(nèi)容的間隔。margin用于布局分開元素使元素與元素互不相干;padding用于元素與內(nèi)容之間的間隔,讓內(nèi)容(文字)與(包裹)元素之間有一段“呼吸距離”。

舉個(gè)例子吧

<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>用Margin還是用Paddingtitle>
<style>
.top{width:160px; height:50px; background:#ccf;}
.middle{width:160px; background:#cfc; border-top:1px solid #ccc;}
.middle .firstChild{margin-top:20px;}
.middle .secondChild{margin-top:15px;}
style>
head>
<body>
<div class="top">div>
<div class="middle">
  <div class="firstChild">我是firstChild,我只是想和我的父元素隔開點(diǎn)距離,這樣看起來舒服。div>
  <div class="secondChild">我要和樓上隔開點(diǎn)的距離。恩,能與底邊有點(diǎn)呼吸距離就更好了。div>
div>
body>
html>

上面這個(gè)效果看起來很不錯(cuò),達(dá)到了我們需要實(shí)現(xiàn)的目標(biāo)。然而,我們細(xì)細(xì)查看下這個(gè)代碼,對(duì)照下我們上文所說的規(guī)則,firstChild用了margin-top:20px來隔開父元素與他的距離,secondChild也用margin-top:15來隔開他與firstChild的距離,咋看之下挺符合我們所說的margin是用來隔開元素與元素的間距。但是他符合我們所說的margin用于布局分開元素使元素與元素互不相干嗎?

這里我想說的是NO,firstChild同middle屬于一種父子元素關(guān)系,又是一種包裹元素與內(nèi)容的關(guān)系,他們之間從擬人化的角度來講,不應(yīng)該是老死不相干的局面。我們?cè)賮砜次覀優(yōu)槭裁匆宖irstChild與他的父元素隔開的距離,從表現(xiàn)的角度上來看,文字與邊靠的太近,肯定不好看。讓文字與元素邊隔開的距離,既美觀,又使得文字有了足夠的“呼吸空間”,方便閱讀,這恰恰符合padding用于元素與內(nèi)容之間的間隔讓內(nèi)容(文字)與(包裹)元素之間有個(gè)“呼吸距離”。

我們?cè)賮砜?,firstChild使用margin-top引發(fā)了垂直外邊距合并的隱患,middle如果不加一個(gè)類似border-top:1px solid #ccc的話標(biāo)準(zhǔn)瀏覽器下就會(huì)呈現(xiàn)子元素頂了父元素margin隱患(這是個(gè)垂直外邊距合并問題,可以查看不要告訴我你懂margin,這篇文章內(nèi)有詳細(xì)介紹)??梢娺@個(gè)時(shí)候margin顯然不是很好的選擇。

我們來試著這么修改:

<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>用Margin還是用Paddingtitle>
<style>
.top{width:160px; height:50px; background:#ccf;}
.middle_2{width:160px; background:#cfc; padding:20px 0px;}
.middle_2 .firstChild{}
.middle_2 .secondChild{margin-top:15px;}
style>
head>
<body>
<div class="top">div>
<div class="middle_2">
  <div class="firstChild">我是firstChild,我只是想和我的父元素隔開點(diǎn)距離,這樣看起來舒服div>
  <div class="secondChild">我是secondChild,我要和樓上隔開點(diǎn)的距離。恩,能與底邊有點(diǎn)呼吸距離就更好了。div>
div>
body>
html>

我們來看看這么寫的好處吧:
1.外觀依舊良好,結(jié)構(gòu)清晰也沒有破壞布局。
2.不會(huì)產(chǎn)生垂直外邊距合并這樣的問題。
3.書寫規(guī)范、代碼量減少、重用性好。

我們可以看到在middle_2中去除了不需要的border-top,改為更為實(shí)用的padding:20px 0,讓middle_2中的內(nèi)容有了足夠的“呼吸空間”,以后還可以隨時(shí)隨地修改這個(gè)padding,讓內(nèi)容文字的“呼吸空間”增大或者縮小,隨時(shí)隨地只修改一個(gè)middle_2的padding就能搞定所有包裹元素與內(nèi)部內(nèi)容的規(guī)劃。

請(qǐng)注意這里是父元素應(yīng)用padding,使得與其內(nèi)容產(chǎn)生間隙,這是符合我們翻譯為“補(bǔ)白”精髓(所以我一直喜歡稱padding為“補(bǔ)白”而不是內(nèi)邊距),而padding也恰恰是在這兒最能體檢他的價(jià)值。這個(gè)例子把第一個(gè)元素的margin-top去除,在父元素中應(yīng)用padding。反過來,你會(huì)想,既然margin-top不好用,那么我第一個(gè)元素用padding-top不是也能達(dá)到效果么。恭喜你,你已經(jīng)前進(jìn)了一步了,的確使用padding-top即讓第一元素與外包裹元素產(chǎn)生了呼吸距離,而且也不會(huì)出現(xiàn)所謂的垂直外邊距重疊問題, 但是我依舊不推薦你這么做。為什么呢?我們來設(shè)想這么一個(gè)情況吧,假如有一天,你這個(gè)模塊要產(chǎn)生變動(dòng),新需求要?jiǎng)h除這個(gè)firstChild,替換為otherChild,會(huì)怎么樣呢?

新的需求要求我們新加一個(gè)otherChild,替換原來的firstChild:

?

<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>用Margin還是用Paddingtitle>
<style>
.top{width:160px; height:50px; background:#ccf;}
.middle_3{width:160px; background:#cfc;}
.middle_3 .otherChild{font-weight:bold; font-style: italic;}
.middle_3 .secondChild{margin-top:10px;}
style>
head>
<body>
<div class="top">div>
<div class="middle_3">
  <div class="otherChild">我是新來的otherChild,我也想和我的父元素隔開點(diǎn)距離,這樣看起來舒服,咦?!為什么我是在頂部?div>
  <div class="secondChild">我是secondChild,我要和樓上隔開點(diǎn)的距離。恩,能與底邊有點(diǎn)呼吸距離就更好了。div>
div>
body>
html>

發(fā)現(xiàn)問題了么?如果你把原先的firstChild給刪除掉了,新來的元素根本就沒有定義上邊距或者上補(bǔ)白,那么他就會(huì)自然頂在頭部,不是理想的效果。的確,你可以為了他新寫一個(gè)css來讓他距離頭部多一點(diǎn)空隙,但是你該怎么寫?直接改otherChild嗎?如果其他頁面里面也有otherChild那么你會(huì)把其他地方的otherChild布局打亂。恩,那么我用.middle_3 .otherChild{padding-top:10px;}怎么樣可以吧。恩,可以可以,可是你不覺得這么累嗎?每次修改,都要增加這一個(gè)多余的代碼就為了簡(jiǎn)簡(jiǎn)單單的隔開點(diǎn)距離,久而久之,你的css文件代碼會(huì)臃腫不堪,可移植性大大削弱。

每次開發(fā)的時(shí)候我一直對(duì)自己講,你寫的代碼總有一天會(huì)被別的開發(fā)人員所替換、修改、更新。而一個(gè)優(yōu)秀的前端寫出的css不但在現(xiàn)在結(jié)構(gòu)堅(jiān)固并且還能為日后的開發(fā)人員提供方便。修改我的代碼,改前改后的式樣位置都一樣,讓之后的開發(fā)人員根本上避免接觸到再次“修復(fù)”開發(fā)的機(jī)會(huì),那才是一名真正前端的追求。這里你把包裹的div類似“封裝”好一個(gè)環(huán)境,而且這個(gè)div內(nèi)已經(jīng)留有足夠的內(nèi)容的“呼吸空間”,你只需要改內(nèi)容,內(nèi)容所要考慮到得位置邊距問題,外包的div元素早已經(jīng)幫你預(yù)留好了,你用起來方便,今后改起來也方便,直接找到middle修改padding即可。

To margin or to be padding, that is the question.

所謂大道萬千,運(yùn)用之妙存乎一心。該用margin的時(shí)候就大膽的用他,該用padding也不用退縮不前,實(shí)戰(zhàn)中累積出來的經(jīng)驗(yàn)往往是最有用的,而當(dāng)你不確定是用margin好還是用padding,請(qǐng)?jiān)诳纯催@個(gè)原則吧,或許你會(huì)有一個(gè)自己的答案。

?

轉(zhuǎn)載注明: 出自?海玉的博客?
本文地址:?http://www.hicss.net/use-margin-or-padding/ 

文章版權(quán)歸作者所有,未經(jīng)允許請(qǐng)勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請(qǐng)注明本文地址:http://m.hztianpu.com/yun/1370.html

相關(guān)文章

  • 轉(zhuǎn)載:瀏覽器常見兼容問題以及解決辦法

    摘要:瀏覽器兼容問題四行內(nèi)屬性標(biāo)簽,設(shè)置后采用布局,又有橫行的的情況,間距問題癥狀里的間距比超過設(shè)置的間距碰到幾率解決方案在后面加入備注行內(nèi)屬性標(biāo)簽,為了設(shè)置寬高,我們需要設(shè)置除了標(biāo)簽比較特殊。 (1)瀏覽器兼容問題一:不同瀏覽器的標(biāo)簽?zāi)J(rèn)的外補(bǔ)丁和內(nèi)補(bǔ)丁不同問題癥狀:隨便寫幾個(gè)標(biāo)簽,不加樣式控制的情況下,各自的margin 和padding差異較大。碰到頻率:100%解決方案:CSS里 *...

    AaronYuan 評(píng)論0 收藏0
  • 轉(zhuǎn)載:瀏覽器常見兼容問題以及解決辦法

    摘要:瀏覽器兼容問題四行內(nèi)屬性標(biāo)簽,設(shè)置后采用布局,又有橫行的的情況,間距問題癥狀里的間距比超過設(shè)置的間距碰到幾率解決方案在后面加入備注行內(nèi)屬性標(biāo)簽,為了設(shè)置寬高,我們需要設(shè)置除了標(biāo)簽比較特殊。 (1)瀏覽器兼容問題一:不同瀏覽器的標(biāo)簽?zāi)J(rèn)的外補(bǔ)丁和內(nèi)補(bǔ)丁不同問題癥狀:隨便寫幾個(gè)標(biāo)簽,不加樣式控制的情況下,各自的margin 和padding差異較大。碰到頻率:100%解決方案:CSS里 *...

    aboutU 評(píng)論0 收藏0
  • 轉(zhuǎn)載:瀏覽器常見兼容問題以及解決辦法

    摘要:瀏覽器兼容問題四行內(nèi)屬性標(biāo)簽,設(shè)置后采用布局,又有橫行的的情況,間距問題癥狀里的間距比超過設(shè)置的間距碰到幾率解決方案在后面加入備注行內(nèi)屬性標(biāo)簽,為了設(shè)置寬高,我們需要設(shè)置除了標(biāo)簽比較特殊。 (1)瀏覽器兼容問題一:不同瀏覽器的標(biāo)簽?zāi)J(rèn)的外補(bǔ)丁和內(nèi)補(bǔ)丁不同問題癥狀:隨便寫幾個(gè)標(biāo)簽,不加樣式控制的情況下,各自的margin 和padding差異較大。碰到頻率:100%解決方案:CSS里 *...

    617035918 評(píng)論0 收藏0
  • 純CSS實(shí)現(xiàn)側(cè)邊欄/分欄高度自動(dòng)相等

    摘要:一為何要分欄高度一致分欄高度一致的目的是更加美觀。二純實(shí)現(xiàn)側(cè)邊欄分欄高度自動(dòng)相等這里直接介紹我認(rèn)為的最佳的側(cè)邊欄分欄高度自動(dòng)相等方法。 一、為何要分欄高度一致?分欄高度一致的目的是更加美觀。舉兩個(gè)例子吧。 ① 對(duì)于分欄布局,我們或許會(huì)用邊框(border)進(jìn)行分隔,就如鄙人博客的分欄:邊框分欄 張?chǎng)涡?鑫空間-鑫生活 此時(shí)最擔(dān)心的問題就是高度不一致,尤其是無邊框?qū)傩缘姆謾诟叨瘸^有邊框...

    li21 評(píng)論0 收藏0
  • 【開發(fā)經(jīng)驗(yàn)】Flutter避免代碼嵌套,寫好build方法

    摘要:意味著屬性必須在構(gòu)造函數(shù)中就被初始化完成,不接受提前定義,也不接受更改。所以,在生命周期中動(dòng)態(tài)的改變對(duì)象的屬性是不可能的,必須使用框架的方法來為構(gòu)造函數(shù)動(dòng)態(tài)指定參數(shù),從而達(dá)到改變組件屬性的功能。 本文適合使用Flutter開發(fā)過一段時(shí)間的開發(fā)者閱讀,旨在分享一種避免Flutter的UI代碼嵌套太深問題的方法。如果對(duì)本文內(nèi)容或觀點(diǎn)有相關(guān)疑問,歡迎在評(píng)論中指出。 優(yōu)化效果(縮略圖): sh...

    Worktile 評(píng)論0 收藏0

發(fā)表評(píng)論

0條評(píng)論

閱讀需要支付1元查看
<