日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

实现圣杯布局与双飞翼布局 原始实现-flex实现-grid实现

發(fā)布時間:2024/1/18 编程问答 34 豆豆
生活随笔 收集整理的這篇文章主要介紹了 实现圣杯布局与双飞翼布局 原始实现-flex实现-grid实现 小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.

文章目錄

  • 實現(xiàn)圣杯布局和雙飛翼布局
    • float + margin負值+relative/添加盒子
      • 前期準備
        • 圣杯布局 margin負值+relative
        • 雙飛翼布局 margin負值+添加盒子
    • flex實現(xiàn)圣杯布局
      • grid實現(xiàn)圣杯布局

實現(xiàn)圣杯布局和雙飛翼布局

本質:三列布局,左右兩邊固定,中間自適應且優(yōu)先加載

優(yōu)先加載:主區(qū)域標簽寫在最前面

<header>頭部</header> <div class="box"><div class="center">主區(qū)域</div><div class="left">左區(qū)域</div><div class="right">右區(qū)域</div> </div> <footer>底部</footer>

float + margin負值+relative/添加盒子

前期準備

1.三個區(qū)域的盒子向左浮動:三欄在一行顯示

.box div{float:left; }

問題:出現(xiàn)高度塌陷
原因:父元素的高度默認被子元素撐開。當子元素浮動后,完全脫離文檔流,子元素將無法撐起父元素的高度,導致父元素的高度丟失。父元素高度丟失后,其下的元素會自動上移,影響布局。

解決辦法:清除浮動
清除浮動是指該元素恢復浮動元素沒有浮動之前的位置
給受影響的盒子添加clear屬性,clear元素的原理是設置清除浮動以后,瀏覽器會自動為元素添加上外邊距,所以添加了clear的屬性不可以手動添加margin-top。

2.清除浮動 不影響后面區(qū)域
原理:在父元素的后面添加一個空標簽(行內元素),清除浮動對其的影響并使其為塊元素,瀏覽器自動改變margin-top使其可以撐開父元素。
需要一個子元素占位,清除浮動的影響,回到應該從撐起來的狀態(tài)。

.box::after{content:"";display:block;clear:both; }


3.中間元素自適應
中間元素自適應:width:100%

.center{background-color: pink;width: 100% }

float 使他們處在了同一行, 只是center把一行都占據(jù)了, 把其他兩個都擠下去了。

圣杯布局 margin負值+relative

  • box設置一個padding:0 100px,將左右兩邊各騰出100px寬度。
    這里就是圣杯布局和雙飛翼布局不一樣的地方!通過padding設置中間區(qū)域的實際大小是不包含左右區(qū)域的。
    ②給左右區(qū)域固定欄騰出位置,我們這里假設左右區(qū)域固定的大小是100px。

  • margin負值移動,將三列布局顯示在一行
    left、right都是被擠下去的,那么將left向左移動一行的距離,left就可以顯示在這一行的最開始了,right只需要向左移動100px就可以在一行顯示了。

  • .left{background-color: red;width: 100px;margin-left: -100%;/*100%相對于父元素來說*/ } .right{background-color: blue;width: 100px;margin-left: -100px; }
  • 將左右區(qū)域定位到固定位置
    relative是參照于元素A原來的位置(開啟相對定位的元素A)在文檔流中的位置進行定位的
  • .left{background-color: red;width: 100px;margin-left: -100%;position: relative;left: -100px; } .right{background-color: blue;width: 100px;margin-left: -100px;position: relative;left: 100px; }

    雙飛翼布局 margin負值+添加盒子

  • margin負值移動,將三列布局顯示在一行 --這一步相同的
  • .left{background-color: red;width: 100px;margin-left: -100%;/*100%相對于父元素來說*/ } .right{background-color: blue;width: 100px;margin-left: -100px; }


    中間區(qū)域的內容不見了,在中間區(qū)域里面添加的一個盒子,并給盒子設置margin:0 200px
    所以說雙飛翼布局,中間區(qū)域center占的還是一行的空間,只是inner占據(jù)到了中間位置

    <div class="header">header</div><div class="box"><div class="center"><div class="inner">主區(qū)域</div></div><div class="left">左區(qū)域</div><div class="right">右區(qū)域</div></div><div class="footer">footer</div> //css .inner{margin: 0 100px; }

    flex實現(xiàn)圣杯布局

  • 先準備好布局
  • <style> /* 設置顏色為了方便看見效果 */ .header,.footer{background-color: blanchedalmond;width: 100%; } .center{background-color: pink; }.left{background-color: red;width: 100px; } .right{background-color: blue;width: 100px; }</style> <body><div class="header">header</div><div class="box"><div class="center">主區(qū)域 </div><div class="left">左區(qū)域</div><div class="right">右區(qū)域</div></div><div class="footer">footer</div></body>


    2. 中間區(qū)域flex:1實現(xiàn)自適應

    .box{display: flex; } .center{background-color: pink;flex:1;/*自適應*/ }
  • 移動位置使得center到中間
  • .center{background-color: pink;flex:1;/*自適應*/order:2;/*移動到中間*/ }.left{background-color: red;width: 100px;order:1; } .right{background-color: blue;width: 100px;order:3; }

    grid實現(xiàn)圣杯布局

    <style> .header,.footer{background-color: blanchedalmond;width: 100%; } .box{display: grid;grid-template-columns:100px 1fr 100px;grid-template-areas: "a b c"; } .center{background-color: pink;grid-area:b ; }.left{background-color: red;width: 100px;grid-area:a } .right{background-color: blue;width: 100px; } </style><body><header>頭部</header><div class="box"><div class="center">主區(qū)域</div><div class="left">左區(qū)域</div><div class="right">右區(qū)域</div></div><footer>底部</footer> </body>

    總結

    以上是生活随笔為你收集整理的实现圣杯布局与双飞翼布局 原始实现-flex实现-grid实现的全部內容,希望文章能夠幫你解決所遇到的問題。

    如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。

    主站蜘蛛池模板: 国产婷婷色一区二区三区在线 | 91黄色小网站| 91色交| 三级av在线免费观看 | 午夜性生活片 | 51精产品一区一区三区 | 国模精品一区二区三区 | 久草电影在线 | 成人动漫免费观看 | 一级做a爰 | 午夜av大片 | 日日射av | 欧美一级二级视频 | 国模少妇一区二区三区 | 中文字字幕在线中文乱码电影 | 久久久久久久久亚洲 | 少妇的被肉日常np | 又紧又大又爽精品一区二区 | 国产精品久线在线观看 | 国产做爰免费观看视频 | 国产亚洲一区二区三区不卡 | 国产日韩一区二区在线观看 | 久久99久 | 人妖天堂狠狠ts人妖天堂狠狠 | www欧美日韩 | av观看国产 | 国产精品人成 | 国产一区二区欧美日韩 | 日韩激情小视频 | 欧美亚洲一区二区在线观看 | 色婷婷久久久亚洲一区二区三区 | 日韩av电影手机在线观看 | 国产在线视频资源 | 美女考逼 | 欧美日韩成人网 | 色老大网站 | 久久久久久av无码免费网站 | 女人裸体免费网站 | 日韩一级片免费 | 中文字幕精品一二三四五六七八 | 在线成人免费观看 | 丰满少妇久久久久久久 | 99爱免费视频 | 精品无码m3u8在线观看 | 女生鸡鸡软件 | 欧美一区二区影院 | 四虎视频国产精品免费 | 在线观看网页视频 | 亚洲综合欧美日韩 | 91网站永久免费看nba视频 | 亚洲视频 欧美视频 | 哺乳喂奶一二三区乳 | 欧美在线一区二区三区 | 神马午夜我不卡 | 少妇久久久久久 | 日本特黄网站 | 精品在线播放 | 日本精品一区二区三区在线观看 | 亚洲iv一区二区三区 | 黄色欧美大片 | 中文字幕精品视频在线观看 | 免费看a网站 | 亚洲靠逼 | 欧洲毛片 | 麻豆av剧情| 黄色成人在线网站 | 蜜臀av在线观看 | 日日躁夜夜躁白天躁晚上躁91 | 38激情| 中文字幕一区二区人妻痴汉电车 | 亚洲高清久久久 | 97在线观看视频免费 | 精品人伦一区二区三区蜜桃免费 | www.-级毛片线天内射视视 | 91网站视频在线观看 | 亚洲国产精一区二区三区性色 | 国产精品久久久久久久久动漫 | 美女福利在线 | 91视频在线看| 91人妻一区二区三区 | 成人a视频在线观看 | 欧美日韩中出 | 国产欧美日韩精品一区 | 国产精品一级片 | 国产一区二区三区视频 | 亚洲精品国产精 | www夜片内射视频日韩精品成人 | 欧美xxxxbbb| 蜜臀久久99精品久久久 | 老外一级黄色片 | 国产成人无码精品 | 欧美精品入口蜜桃 | 中文字幕高清一区 | v99av| 欧美性生交xxxxx久久久缅北 | 国产第七页 | 亚洲精品婷婷 | 国产又粗又爽视频 | 九九色综合网 |