web前端之CSS 布局經(jīng)典問題整理

CSS 定位問題

主要就是經(jīng)典的絕對定位申尤,相對定位問題滚粟。

10個文檔學布局:通過十個例子講解布局寻仗,主要涉及相對布局,絕對布局凡壤,浮動署尤。

HTML和CSS高級指南之二——定位詳解(譯文):介紹浮動的使用,詳細介紹定位的技巧亚侠,包括如何準確的給元素在 X 軸曹体、Y 軸和 Z 軸定位

三欄式布局

涉及浮動和清除浮動,主要講解“圣杯”和“雙飛翼”兩種解決方法硝烂。這兩種方法實現(xiàn)的都是三欄布局箕别,兩邊的盒子寬度固定,中間盒子自適應(yīng)钢坦,它們實現(xiàn)的效果是一樣的究孕,差別在于其實現(xiàn)的思想。

圣杯布局

圣杯:父盒子包含三個子盒子(左爹凹,中厨诸,右)

中間盒子的寬度設(shè)置為 width: 100%; 獨占一行;

使用負邊距(均是 margin-left)把左右兩邊的盒子都拉上去和中間盒子同一行禾酱;

.* left {margin-left:-100%;} 把左邊的盒子拉上去

.right {margin-left:-右邊盒子寬度px;} 把右邊的盒子拉上去

父盒子設(shè)置左右的 padding 來為左右盒子留位置微酬;

對左右盒子使用相對布局來占據(jù) padding 的空白,避免中間盒子的內(nèi)容被左右盒子覆蓋颤陶;

雙飛翼布局

雙飛翼:父盒子包含三個子盒子(左颗管,中,右)滓走,中間的子盒子里再加一個子盒子垦江。

中間盒子的寬度設(shè)置為 width: 100%; 獨占一行;

使用負邊距(均是 margin-left)把左右兩邊的盒子都拉上去和中間盒子同一行搅方;

在中間盒子里面再添加一個 div比吭,然后對這個 div 設(shè)置 margin-left 和 margin-right來為左右盒子留位置绽族;

圣杯和雙飛翼異同

圣杯布局和雙飛翼布局解決的問題是一樣的,都是兩邊定寬衩藤,中間自適應(yīng)的三欄布局吧慢,中間欄要在放在文檔流前面以優(yōu)先渲染。

兩種方法基本思路都相同:首先讓中間盒子 100% 寬度占滿同一高度的空間赏表,在左右兩個盒子被擠出中間盒子所在區(qū)域時检诗,使用 margin-left 的負值將左右兩個盒子拉回與中間盒子同一高度的空間。接下來進行一些調(diào)整避免中間盒子的內(nèi)容被左右盒子遮擋瓢剿。

主要區(qū)別在于 如何使中間盒子的內(nèi)容不被左右盒子遮擋:

圣杯布局的方法:設(shè)置父盒子的 padding 值為左右盒子留出空位逢慌,再利用相對布局對左右盒子調(diào)整位置占據(jù) padding 出來的空位;

雙飛翼布局的方法:在中間盒子里再增加一個子盒子跋选,直接設(shè)置這個子盒子的 margin 值來讓出空位涕癣,而不用再調(diào)整左右盒子哗蜈。

簡單說起來就是雙飛翼布局比圣杯布局多創(chuàng)建了一個 div前标,但不用相對布局了,少設(shè)置幾個屬性距潘。

利用浮動實現(xiàn)

我自己使用浮動也實現(xiàn)了三欄式布局:左邊盒子左浮動炼列,右邊盒子右浮動,中間盒子利用 margin-left 和 margin-right 來為左右盒子留位置音比,同時父盒子設(shè)置 overflow: auto; 來避免子盒子溢出俭尖。

三欄式布局涉及到負 magin 和 清除浮動的問題。

負 magin

簡單總結(jié)幾點:

不使用 float 的話洞翩,負 margin 元素是不會破壞頁面的文檔流稽犁。所以如果你使用負 margin 上移一個元素,所有跟隨的元素都會被上移(而 relative 定位的元素則不同骚亿,會保留原位置已亥,影響文檔流)。

當 static 元素的 margin-top/margin-left 被賦予負值時来屠,元素將被拉進指定的方向虑椎。

如果你設(shè)置 margin-bottom/right 為負數(shù),元素并不會如你所想的那樣向下/右移動俱笛,而是將后續(xù)的元素拖拉進來捆姜,覆蓋本來的元素。

當元素不存在 width 屬性或者 width: auto 的時候迎膜,負 margin 會增加元素的寬度.

margin-top 為負值不會增加高度泥技,只會產(chǎn)生向上位移;margin-bottom 為負值不會產(chǎn)生位移,會減少自身的供 CSS 讀取的高度磕仅,影響下方的元素位置珊豹;上下相鄰的元素兩者均為負時镊讼,效果不疊加,取負值更多的那個效果平夜。

清除浮動

清除浮動主要是為了解決高度塌陷問題蝶棋。而簡單的 clear: both 并不能解決這個問題,所以引出了許多解決方案忽妒。

StackOverflow – What methods of ‘clearfix’ can I use?:清除浮動黑科技完整解讀

那些年我們一起清除過的浮動:神文玩裙,把“清除浮動”定義為“閉合浮動”,把問題由來和解決方案都講清楚了段直,并且分析了各種解決方案的優(yōu)劣吃溅。

各種解決方案在上面的鏈接里有很詳細的說明了,這里就不贅述了鸯檬。大體分為兩類:

其一决侈,通過在浮動元素的末尾添加一個空元素,設(shè)置 clear: both 屬性喧务,after 偽元素其實也是通過 content 在元素的后面生成了內(nèi)容為一個點的塊級元素赖歌;

其二,通過設(shè)置父元素 overflow 或者 display: table 屬性來閉合浮動

順便補充一句功茴,clear float(例如 clear: left) 是對某個元素設(shè)置庐冯,以避免其某一邊有浮動元素,即對當前元素產(chǎn)生約束坎穿,約束的邊界為其他的浮動元素展父。對于已經(jīng)浮動的元素,設(shè)置 clear float 是無效的玲昧。

居中布局

Centering in CSS: A Complete Guide:非常全面的居中定位博客栖茉,包括各種情況下的水平居中,垂直居中和水平垂直居中方案孵延。有展示示例及相應(yīng)的 HTML 和 CSS 代碼

文章大致結(jié)構(gòu):

水平居中

對于行內(nèi)元素(inline):text-align: center;

對于塊級元素(block):設(shè)置寬度且 marigin-left 和 margin-right 是設(shè)成 auto

對于多個塊級元素:對父元素設(shè)置 text-align: center;吕漂,對子元素設(shè)置 display: inline-block;;或者使用 flex 布局

垂直居中

對于行內(nèi)元素(inline)

單行:設(shè)置上下 pandding 相等隙袁;或者設(shè)置 line-height 和 height 相等

多行:設(shè)置上下 pandding 相等痰娱;或者設(shè)置 display: table-cell; 和 vertical-align: middle;;或者使用 flex 布局菩收;或者使用偽元素

對于塊級元素(block):下面前兩種方案梨睁,父元素需使用相對布局

已知高度:子元素使用絕對布局 top: 50%;,再用負的 margin-top 把子元素往上拉一半的高度

未知高度:子元素使用絕對布局 position: absolute; top: 50%; transform: translateY(-50%);

使用 Flexbox:選擇方向娜饵,justify-content: center;

水平垂直居中

定高定寬:先用絕對布局 top: 50%; left: 50%;坡贺,再用和寬高的一半相等的負 margin 把子元素回拉

高度和寬度未知:先用絕對布局 top: 50%; left: 50%;,再設(shè)置 transform: translate(-50%, -50%);

使用 Flexbox:justify-content: center; align-items: center;

響應(yīng)式設(shè)計

“響應(yīng)式設(shè)計(Responsive Design)” 是一種讓網(wǎng)站針對不同的瀏覽器和設(shè)備“呈現(xiàn)”不同顯示效果的策略。

媒體查詢(Media Queries)是做此事所需的最強大的工具遍坟。

注: Responsive Web Design = RWD拳亿,Adaptive Web Design = AWD

RWD:

采用 CSS 的 media query 技術(shù)

流體布局(fluid grids)

自適應(yīng)的圖片/視頻等資源素材

(為小、中愿伴、大屏幕做一些優(yōu)化肺魁,目的是讓任何尺寸的屏幕空間都能得到充分利用)

AWD:

CSS media query 技術(shù)(僅針對有限幾種預設(shè)的屏幕尺寸設(shè)計)

用 JavaScript 來操作 HTML 內(nèi)容

在服務(wù)器端操作 HTML 內(nèi)容(比如為移動端減少內(nèi)容,為桌面端提供更多內(nèi)容)

Flexbox 布局

Flexbox 布局參考下面幾篇文章就可以了隔节,幾篇文章大同小異鹅经,看一兩篇就知道大概了,講的挺詳細的怎诫,在此不贅述

w3cplus – 一個完整的Flexbox指南:A Complete Guide to Flexbox 的譯文

SegmentFault – Flexbox詳解

w3cplus – 圖解CSS3 Flexbox屬性

w3cplus – Flexbox——快速布局神器

最后:

“相信有很多想學前端的小伙伴瘾晃,今年年初我花了一個月整理了一份最適合2018年學習的web前端干貨,從最基礎(chǔ)的HTML+CSS+JS到移動端HTML5等都有整理幻妓,送給每一位前端小伙伴蹦误,53763,1707這里是小白聚集地肉津,歡迎初學和進階中的小伙伴强胰。”

祝大家早日學有所成阀圾,拿到滿意offer哪廓,快速升職加薪狗唉,走上人生巔峰初烘。

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市分俯,隨后出現(xiàn)的幾起案子肾筐,更是在濱河造成了極大的恐慌,老刑警劉巖缸剪,帶你破解...
    沈念sama閱讀 217,542評論 6 504
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件吗铐,死亡現(xiàn)場離奇詭異,居然都是意外死亡杏节,警方通過查閱死者的電腦和手機唬渗,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,822評論 3 394
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來奋渔,“玉大人镊逝,你說我怎么就攤上這事〖稻ǎ” “怎么了撑蒜?”我有些...
    開封第一講書人閱讀 163,912評論 0 354
  • 文/不壞的土叔 我叫張陵,是天一觀的道長。 經(jīng)常有香客問我座菠,道長狸眼,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,449評論 1 293
  • 正文 為了忘掉前任浴滴,我火速辦了婚禮拓萌,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘升略。我一直安慰自己司志,他們只是感情好,可當我...
    茶點故事閱讀 67,500評論 6 392
  • 文/花漫 我一把揭開白布降宅。 她就那樣靜靜地躺著骂远,像睡著了一般。 火紅的嫁衣襯著肌膚如雪腰根。 梳的紋絲不亂的頭發(fā)上激才,一...
    開封第一講書人閱讀 51,370評論 1 302
  • 那天,我揣著相機與錄音额嘿,去河邊找鬼瘸恼。 笑死,一個胖子當著我的面吹牛册养,可吹牛的內(nèi)容都是我干的东帅。 我是一名探鬼主播,決...
    沈念sama閱讀 40,193評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼球拦,長吁一口氣:“原來是場噩夢啊……” “哼靠闭!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起坎炼,我...
    開封第一講書人閱讀 39,074評論 0 276
  • 序言:老撾萬榮一對情侶失蹤愧膀,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后谣光,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體檩淋,經(jīng)...
    沈念sama閱讀 45,505評論 1 314
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,722評論 3 335
  • 正文 我和宋清朗相戀三年萄金,在試婚紗的時候發(fā)現(xiàn)自己被綠了蟀悦。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 39,841評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡氧敢,死狀恐怖日戈,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情福稳,我是刑警寧澤涎拉,帶...
    沈念sama閱讀 35,569評論 5 345
  • 正文 年R本政府宣布瑞侮,位于F島的核電站,受9級特大地震影響鼓拧,放射性物質(zhì)發(fā)生泄漏半火。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 41,168評論 3 328
  • 文/蒙蒙 一季俩、第九天 我趴在偏房一處隱蔽的房頂上張望钮糖。 院中可真熱鬧,春花似錦酌住、人聲如沸店归。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,783評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽消痛。三九已至,卻和暖如春都哭,著一層夾襖步出監(jiān)牢的瞬間秩伞,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 32,918評論 1 269
  • 我被黑心中介騙來泰國打工欺矫, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留纱新,地道東北人。 一個月前我還...
    沈念sama閱讀 47,962評論 2 370
  • 正文 我出身青樓穆趴,卻偏偏與公主長得像脸爱,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子未妹,可洞房花燭夜當晚...
    茶點故事閱讀 44,781評論 2 354

推薦閱讀更多精彩內(nèi)容

  • 問答題47 /72 常見瀏覽器兼容性問題與解決方案簿废? 參考答案 (1)瀏覽器兼容問題一:不同瀏覽器的標簽?zāi)J的外補...
    _Yfling閱讀 13,751評論 1 92
  • 三欄式布局 涉及浮動和清除浮動,主要講解“圣杯”和“雙飛翼”兩種解決方法教寂。這兩種方法實現(xiàn)的都是三欄布局捏鱼,兩邊的盒子...
    紫電倚青霜閱讀 2,374評論 0 6
  • 學會使用CSS選擇器熟記CSS樣式和外觀屬性熟練掌握CSS各種選擇器熟練掌握CSS各種選擇器熟練掌握CSS三種顯示...
    七彩小鹿閱讀 6,314評論 2 66
  • 情非得已如何停留疏離之美不必央求 疏離之美不必央求 淚如雨下如何填滿花腔婉轉(zhuǎn)鶯鶯燕燕 花腔婉轉(zhuǎn)鶯鶯燕燕 你的戲服繡...
    微生如故閱讀 263評論 0 1
  • 一縷馨香 幽幽的飄來 哦 梔子花開啦 曾經(jīng) 那花 開在 阡陌的鄉(xiāng)村中 開在 莊戶人家的堂前屋后 開在 秧苗的田埂旁...
    相逢萍水閱讀 321評論 -1 2