淺談雙飛翼布局和圣杯布局(一)

雙飛翼布局和圣杯布局都是實現(xiàn)兩邊固定中間自適應(yīng)的三欄布局的方式,最近在整理三欄布局實現(xiàn)方式的筆記,決定但拉出來一篇,記一下這兩個經(jīng)典布局。

1、圣杯布局

浮動、負邊距、相對定位、不添加額外標簽

效果圖


DOM結(jié)構(gòu):

<div class="header">Header</div>
<div class="bd">
    <div class="main">Main</div>
    <div class="left">Left</div>
    <div class="right">Right
    </div>
</div>
<div class="footer">Footer</div>

樣式:

<style>
        body{padding:0;margin:0}
        .header,.footer{width:100%;  background: #666;height:30px;clear:both;}
        .bd{
            padding-left:150px;
            padding-right:190px;
        }
        .left{
            background: #E79F6D;
            width:150px;
            float:left;
            margin-left:-100%;
            position: relative;
            left:-150px;
        }
        .main{
            background: #D6D6D6;
            width:100%;
            float:left;

        }
        .right{
            background: #77BBDD;
            width:190px;
            float:left;
            margin-left:-190px;
            position:relative;
            right:-190px;
        }
    </style>

左中右部分樣式變化過程
1、中間部分需要根據(jù)瀏覽器寬度的變化而變化,所以要用100%,這里設(shè)*左中右向左浮動,因為中間100%,左層和右層根本沒有位置上去

      .left{
            background: #E79F6D;
            width:150px;
            float:left;
        }
        .main{
            background: #D6D6D6;
            width:100%;
            float:left;

        }
        .right{
            background: #77BBDD;
            width:190px;
            float:left;
        }


2、把左層負margin150后,發(fā)現(xiàn)left上去了,因為負到出窗口沒位置了,只能往上挪

.left{ 
   background: #E79F6D; 
   width:150px; 
   float:left; 
   margin-left:-150px; 
}


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

.left{ 
  background: #E79F6D; 
  width:150px; 
  float:left; 
  margin-left:-100%; 
}
.right{ 
  background: #77BBDD; 
  width:190px; 
  float:left; 
  margin-left:-190px; 
}


4、然而問題來了,中間被左右擋住了啊,只好給外層加padding了

.bd{ 
  padding-left:150px; 
  padding-right:190px;
}


5、但是加了之后左右欄也縮進來了,于是采用相對定位方法,各自相對于自己把自己挪出去,得到最終結(jié)果

.left{ 
  background: #E79F6D; 
  width:150px; 
  float:left; 
  margin-left:-100%; 
  position: relative; 
  left:-150px; 
} 
.right{ 
  background: #77BBDD; 
  width:190px; 
  float:left; 
  margin-left:-190px; 
  position:relative; 
  right:-190px; 
}
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

  • 問答題47 /72 常見瀏覽器兼容性問題與解決方案? 參考答案 (1)瀏覽器兼容問題一:不同瀏覽器的標簽?zāi)J的外補...
    _Yfling閱讀 14,150評論 1 92
  • 在前端布局中,事實上,圣杯布局其實和雙飛翼布局是一回事。它們實現(xiàn)的都是三欄布局,兩邊的盒子寬度固定,中間盒子自適應(yīng)...
    風銘閱讀 1,565評論 1 6
  • 首先談?wù)勅龣诓季?三欄布局長什么樣子?三欄布局是左右兩側(cè)浮動,而中間寬度自適應(yīng)不浮動做出的效果。三欄布局 三欄布局...
    大春春閱讀 2,145評論 5 24
  • 在百度前端技術(shù)學院2016的春季任務(wù)中,第一階段系列任務(wù)作為基礎(chǔ)練習,主要是讓學員熟練html及css。其中,ta...
    夜來小星閱讀 646評論 0 7
  • 問題1:圣杯布局的原理是怎樣的? 簡述實現(xiàn)圣杯布局的步驟。 原理大致是這樣的:采用負邊距使得浮動元素達到預(yù)設(shè)的位置...
    饑人谷_小霾閱讀 238評論 0 0

友情鏈接更多精彩內(nèi)容