轉載:CSS實現三欄佈局的四種方法示例

来源:http://www.cnblogs.com/lraa/archive/2017/02/11/6389951.html
-Advertisement-
Play Games

轉載網址:http://www.jb51.net/css/529846.html 前言 其實不管是三欄佈局還是兩欄佈局都是我們在平時項目里經常使用的,也許你不知道什麼事三欄佈局什麼是兩欄佈局但實際已經在用,或許你知道三欄佈局的一種或兩種方法,但實際操作中也只會依賴那某一種方法,本文具體的介紹了三欄布 ...


轉載網址:http://www.jb51.net/css/529846.html

前言

其實不管是三欄佈局還是兩欄佈局都是我們在平時項目里經常使用的,也許你不知道什麼事三欄佈局什麼是兩欄佈局但實際已經在用,或許你知道三欄佈局的一種或兩種方法,但實際操作中也只會依賴那某一種方法,本文具體的介紹了三欄佈局的四種方法,並介紹了它的使用場景。

所謂三欄佈局就是指頁面分為左中右三部分然後對中間一部分做自適應的一種佈局方式。

1.絕對定位法

HTML代碼如下:

<div class="left">Left</div>
<div class="main">Main</div>
<div class="right">Right</div>

 

CSS代碼如下:
//簡單的進行CSS reset
body,html{
    height:100%;
    padding: 0px;
    margin:0px;
}
//左右絕對定位
.left,.right{
    position: absolute;
    top:0px;
    background: red;
    height:100%;
}
.left{
    left:0;
    width:100px;
}
.right{
    right:0px;
    width:200px;
}
//中間使用margin空出左右元素所占據的空間
.main{
    margin:0px 200px 0px 100px;
    height:100%;
    background: blue;
}

該方法有個明顯的缺點,就是如果中間欄含有最小寬度限制,或是含有寬度的內部元素,當瀏覽器寬度小到一定程度,會發生層重疊的情況。

2. 聖杯佈局

HTML代碼如下:

//註意元素次序
<div class="main">Main</div>
<div class="left">Left</div>
<div class="right">Right</div>

CSS代碼如下:

//習慣性的CSS reset
body,html{
    height:100%;
    padding: 0;
    margin: 0
}
//父元素body空出左右欄位
body {
    padding-left: 100px;
    padding-right: 200px;
}
//左邊元素更改
.left {
    background: red;
    width: 100px;
    float: left;
    margin-left: -100%;
    position: relative;
    left: -100px;
    height: 100%;
}
//中間部分
.main {
    background: blue;
    width: 100%;
    height: 100%;
    float: left;
}
//右邊元素定義
.right {
    background: red;
    width: 200px;
    height: 100%;
    float: left;
    margin-left: -200px;
    position: relative;
    right: -200px;
}

相關解釋如下:

      (1)中間部分需要根據瀏覽器寬度的變化而變化,所以要用100%,這裡設左中右向左浮動,因為中間100%,左層和右層根本沒有位置上去

      (2)把左層margin負100後,發現left上去了,因為負到出視窗沒位置了,只能往上挪

      (3)按第二步這個方法,可以得出它只要挪動視窗寬度那麼寬就能到最左邊了,利用負邊距,把左右欄定位

      (4)但由於左右欄遮擋住了中間部分,於是採用相對定位方法,各自相對於自己把自己挪出去,得到最終結果

3. 雙飛翼佈局

HTML代碼如下:

<div class="main">
    <div class="inner">
        Main
    </div>
</div>
<div class="left">Left</div>
<div class="right">Right</div>

CSS代碼如下:

//CSS reset
body,html {
    height:100%;
    padding: 0;
    margin: 0
}
body {
    /*padding-left:100px;*/
    /*padding-right:200px;*/
}
.left {
    background: red;
    width: 100px;
    float: left;
    margin-left: -100%;
    height: 100%;
    /*position: relative;*/
    /*left:-100px;*/
}
.main {
    background: blue;
    width: 100%;
    float: left;
    height: 100%;
}
.right {
    background: red;
    width: 200px;
    float: left;
    margin-left: -200px;
    height: 100%;
    /*position:relative;*/
    /*right:-200px;*/
}
//新增inner元素
.inner {
    margin-left: 100px;
    margin-right: 200px;
}

聖杯佈局實際看起來是複雜的後期維護性也不是很高,在淘寶UED的探討下,出來了一種新的佈局方式就是雙飛翼佈局,代碼如上。增加多一個div就可以不用相對佈局了,只用到了浮動和負邊距。和聖杯佈局差異的地方已經被註釋。

4. 浮動

HTML代碼如下:

//註意元素次序
<div class="left">Left</div>
<div class="right">Right</div>
<div class="main">Main</div>

CSS代碼如下:

//CSS reset
body,html {
    height:100%;
    padding: 0;
    margin: 0
}
//左欄左浮動
.left {
    background: red;
    width: 100px;
    float: left;
    height: 100%;
}
//中間自適應
.main {
    background: blue;
    height: 100%;
    margin:0px 200px 0px 100px;
}
//右欄右浮動
.right {
    background: red;
    width: 200px;
    float: right;
    height: 100%;
}

這種方式代碼足夠簡潔與高效,也容易理解

總結

以上就是這篇文章的全部內容了,四種方法其實只有聖杯佈局和雙飛翼佈局較難理解,但實際上理解了聖杯佈局,雙飛翼佈局自然就理解了,希望本文的內容對大家的學習或者工作能帶來一定的幫助,如有疑問大家可以留言交流。


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 前言 之前用 npm 安裝過 nvm,就以為安裝成功了,但運行 nvm 就報如下提示: This is not the package you are looking for: please go to http://nvm.sh 安裝NVM 查資料得出,要使用 curl 或 wget 來安裝... ...
  • 如今前端界angular react vue三大框架並駕齊驅,其中有一個共同點就是組件化開發,這也符合w3c 推行Web Components的趨勢。現如今不懂組件化開發的前端絕對不是好廚子。跳槽新公司pc端使用angular1.5的Components比較多,趁著入職前幾天自己看一下。 由於ang ...
  • 原文:intro-to-vue-3-vue-cli-lifecycle-hooks 譯者:nzbin 這是 JavaScript 框架 Vue.js 五篇教程的第三部分。在這一部分,我們將學習 Vue-cli ,還會涉及真實的開發流程。這不是一個完整的指南,而是基礎知識的概述,所以你可以瞭解 Vue ...
  • 今天自己寫css樣式,其中用到了<ul>標簽,設置了一系列效果後運行,發現位置與設置有出入。chrome上打開檢查項,發現<ul>標簽的styles底部多了以下一段: ul, menu, dir { ul, menu, dir { display: block; list-style-type: d ...
  • 懶載入技術是現在許多大型網站的都使用的提高網站性能的方式,它的核心思想是當用戶想看頁面某個區域時,再載入該區域的數據。這在一定程度上減輕了伺服器端的壓力,也加快了頁面的呈現速度。 其實國內很多網站都用到了懶載入技術,比如國內兩個大型電商網站的頁面都運用到了這項技術: 天貓首頁: 京東商品列表頁: 最 ...
  • 前言: 關於前端的第二篇博客,會寫關於css的,內容比較基礎。寫完這篇博客,會做一個類似美樂樂傢具的界面。good luck to me~ 一、css-引用樣式 標簽上設置style屬性: 引用樣式的三種方式: 第一種:在<body>直接定義與引用樣式 第二種: 在<head>頭部加上下麵代碼(類似 ...
  • 兩個部分,一個是如題的直接上代碼;二是外一則的小體會。 2.js裡面的this對象 var A={a:function(e){alert(e)},b:function(){console.log(this);this.a(1)}} A.b();//直接這樣調用不報錯,控制台裡面看到this是一個有a ...
  • 頁面DOM里的每個節點上都有一個classList對象,程式員可以使用裡面的方法新增、刪除、修改節點上的CSS類。使用classList,程式員還可以用它來判斷某個節點是否被賦予了某個CSS類。 添加類(add) 為 <div> 元素添加多個類: 移除類(remove) 使用remove方法,你可以 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...