成人国产在线小视频_日韩寡妇人妻调教在线播放_色成人www永久在线观看_2018国产精品久久_亚洲欧美高清在线30p_亚洲少妇综合一区_黄色在线播放国产_亚洲另类技巧小说校园_国产主播xx日韩_a级毛片在线免费

資訊專欄INFORMATION COLUMN

Are you sure you understand the responsive layout?

Shisui / 871人閱讀

摘要:我們推薦使用作為字體單位默認(rèn)情況下我們標(biāo)簽的為,我們可以利用媒體查詢,設(shè)置在不同設(shè)備下的字體大小百分比布局用過的同學(xué)都知道,它里面有個(gè)柵格系統(tǒng),說(shuō)白了就是利用百分比來(lái)定義我們?cè)貙捀撸恢苯邮褂谩?/p>

曾幾何時(shí)我認(rèn)為使用了媒體查詢就是響應(yīng)式布局,這種理解實(shí)在是太淺薄了,今天就讓我們重新來(lái)認(rèn)識(shí)下什么是響應(yīng)式布局

查看demo

查看源碼,歡迎star

什么是響應(yīng)式布局

前幾年風(fēng)靡一時(shí)Bootstrap就是很典型的響應(yīng)式布局框架,雖然現(xiàn)在已經(jīng)被淘汰了,但是現(xiàn)在流行的一些UI框架都是借鑒Bootstrap的思想來(lái)實(shí)現(xiàn)了響應(yīng)式布局,如Ant Design,Material Design等,可以說(shuō)Bootstrap開啟了響應(yīng)式布局的時(shí)代

我用過幾款響應(yīng)式布局框架,自己也研究過響應(yīng)式布局的原理,我認(rèn)為真正的響應(yīng)式布局應(yīng)該是:

我們的網(wǎng)站使用一套代碼,兼容多個(gè)終端設(shè)備,在不同的設(shè)備上會(huì)做出不同的調(diào)整,如顯示或者隱藏等

點(diǎn)我體驗(yàn)

響應(yīng)式布局的要點(diǎn)

當(dāng)你想要實(shí)現(xiàn)一個(gè)響應(yīng)式布局,你需要注意以下幾點(diǎn)

設(shè)置viewport

我們所做的第一件事就是設(shè)置viewport,添加如下代碼到你的head標(biāo)簽中

上面這段代碼的作用是設(shè)置我們網(wǎng)頁(yè)的寬度為設(shè)備的寬度,初始化縮放為1,并且禁止用戶縮放

媒體查詢

媒體查詢是響應(yīng)式布局的核心,我們的網(wǎng)頁(yè)為什么能夠根據(jù)窗口的大小自動(dòng)調(diào)整樣式都是依靠媒體查詢

媒體類型
@media all {} // 用于所有設(shè)備
@media print {} // 用于打印機(jī)
@media screen {} // 用于PC,Pad,Phone
媒體特性

媒體特性有以下可選項(xiàng)

媒體特性 取值 接受max或min 描述
width yes 定義輸出設(shè)備中的頁(yè)面可見區(qū)域?qū)挾?/td>
height yes 定義輸出設(shè)備中的頁(yè)面可見區(qū)域高度
device-width yes 定義輸出設(shè)備的屏幕可見寬度
device-height yes 定義輸出設(shè)備的屏幕可見高度
orientation portrait,landscape no height是否大于width
aspect-ratio yes width和height的比率
device-aspect-ratio yes device-width和device-height的比率
resolution yes 定義設(shè)備的分辨率
-webkit-device-pixel-ratio yes 設(shè)備像素比
移動(dòng)優(yōu)先

移動(dòng)優(yōu)先就是我們寫的樣式以移動(dòng)端為主,當(dāng)隨著屏幕寬度增大的時(shí)候,后面的樣式會(huì)覆蓋前面的樣式,請(qǐng)看下面:

/* iphone6 7 8 */
body {
    background-color: yellow;
}
/* iphone 5 */
@media screen and (max-width: 320px) {
    body {
      background-color: red;
    }
}
/* iphoneX */
@media screen and (min-width: 375px) and (-webkit-device-pixel-ratio: 3) {
    body {
      background-color: #0FF000;
    }
}
/* iphone6 7 8 plus */
@media screen and (min-width: 414px) {
    body {
      background-color: blue;
    }
}
/* ipad */
@media screen and (min-width: 768px) {
    body {
      background-color: green;
    }
}
/* ipad pro */
@media screen and (min-width: 1024px) {
    body {
      background-color: #FF00FF;
    }
}
/* pc */
@media screen and (min-width: 1100px) {
    body {
      background-color: black;
    }
}
PC優(yōu)先

PC優(yōu)先與移動(dòng)端優(yōu)先正好相反,我們編寫的樣式以PC端為主,然后隨著屏幕的寬度的減小,后面的樣式會(huì)覆蓋前面的樣式,請(qǐng)看下面:

/* pc width > 1024px */
    body {
        background-color: yellow;
    }
/* ipad pro */
@media screen and (max-width: 1024px) {
    body {
        background-color: #FF00FF;
    }
}
/* ipad */
@media screen and (max-width: 768px) {
    body {
        background-color: green;
    }
}
/* iphone6 7 8 plus */
@media screen and (max-width: 414px) {
    body {
        background-color: blue;
    }
}
/* iphoneX */
@media screen and (max-width: 375px) and (-webkit-device-pixel-ratio: 3) {
    body {
        background-color: #0FF000;
    }
}
/* iphone6 7 8 */
@media screen and (max-width: 375px) and (-webkit-device-pixel-ratio: 2) {
    body {
        background-color: #0FF000;
    }
}
/* iphone5 */
@media screen and (max-width: 320px) {
    body {
        background-color: #0FF000;
    }
}

大家注意到?jīng)]有PC端優(yōu)先使用的是max-width,而移動(dòng)端優(yōu)先使用的是min-width,這個(gè)技巧大家有沒get到

字體單位

由于我們要做響應(yīng)式布局,我們的字體大小也要隨著屏幕的大小進(jìn)行改變,這時(shí)候就不能使用px作為字體單位了,我們可以使用em或者rem,這兩者的區(qū)別是一個(gè)是相對(duì)于父元素,一個(gè)是相對(duì)于html標(biāo)簽。我們推薦使用rem作為字體單位

默認(rèn)情況下我們html標(biāo)簽的font-size為16px,我們可以利用媒體查詢,設(shè)置在不同設(shè)備下的字體大小

/* pc width > 1100px */
html{ font-size: 100%;}
body {
    background-color: yellow;
    font-size: 1.5rem;
}
/* ipad pro */
@media screen and (max-width: 1024px) {
    body {
      background-color: #FF00FF;
      font-size: 1.4rem;
    }
}
/* ipad */
@media screen and (max-width: 768px) {
    body {
      background-color: green;
      font-size: 1.3rem;
    }
}
/* iphone6 7 8 plus */
@media screen and (max-width: 414px) {
    body {
      background-color: blue;
      font-size: 1.25rem;
    }
}
/* iphoneX */
@media screen and (max-width: 375px) and (-webkit-device-pixel-ratio: 3) {
    body {
      background-color: #0FF000;
      font-size: 1.125rem;
    }
}
/* iphone6 7 8 */
@media screen and (max-width: 375px) and (-webkit-device-pixel-ratio: 2) {
    body {
      background-color: #0FF000;
      font-size: 1rem;
    }
}
/* iphone5 */
@media screen and (max-width: 320px) {
    body {
      background-color: #0FF000;
      font-size: 0.75rem;
    }
}
百分比布局

用過Bootstrap的同學(xué)都知道,它里面有個(gè)柵格系統(tǒng),說(shuō)白了就是利用百分比來(lái)定義我們?cè)貙捀?,而不直接使用width。css3支持了最大最小寬高,可以將百分比和max(min)一起結(jié)合使用來(lái)定義元素在不同設(shè)備下的寬高

/* pc width > 1100px */
html, body { margin: 0;padding: 0;width: 100%;height: 100%;}
aside {
    width: 10%;
    height: 100%;
    background-color: red;
    float: left;
}
main {
    height: 100%;
    background-color: blue;
    overflow: hidden;
}
/* ipad pro */
@media screen and (max-width: 1024px) {
    aside {
      width: 8%;
      background-color: yellow;
    }
}
/* ipad */
@media screen and (max-width: 768px) {
    aside {
      float: none;
      width: 100%;
      height: 10%;
      background-color: green;
    }
    main {
      height: calc(100vh - 10%);
      background-color: red;
    }
}
/* iphone6 7 8 plus */
@media screen and (max-width: 414px) {
    aside {
      float: none;
      width: 100%;
      height: 5%;
      background-color: yellow;
    }
    main {
      height: calc(100vh - 5%);
      background-color: red;
    }
}
/* iphoneX */
@media screen and (max-width: 375px) and (-webkit-device-pixel-ratio: 3) {
    aside {
      float: none;
      width: 100%;
      height: 10%;
      background-color: blue;
    }
    main {
      height: calc(100vh - 10%);
      background-color: red;
    }
}
/* iphone6 7 8 */
@media screen and (max-width: 375px) and (-webkit-device-pixel-ratio: 2) {
    aside {
      float: none;
      width: 100%;
      height: 3%;
      background-color: black;
    }
    main {
      height: calc(100vh - 3%);
      background-color: red;
    }
}
/* iphone5 */
@media screen and (max-width: 320px) {
    aside {
      float: none;
      width: 100%;
      height: 7%;
      background-color: green;
    }
    main {
      height: calc(100vh - 7%);
      background-color: red;
    }
}
圖片自適應(yīng)

圖片自適應(yīng)意思就是圖片能隨著容器的大小進(jìn)行縮放,可以采用如下代碼:

img {
    max-width: 100%;
    height: auto;
}

max-width保證了圖片能夠隨著容器的進(jìn)行等寬擴(kuò)充,而height為auto可以保證圖片進(jìn)行等比縮放而不至于失真

如果是背景圖片的話要靈活運(yùn)用background-size屬性

flex,grid,絕對(duì)布局,BFC

除此之外還要靈活運(yùn)用flex布局,grid布局,絕對(duì)布局,BFC等

最后

再總結(jié)下,實(shí)現(xiàn)一個(gè)響應(yīng)式布局我們要注意以下幾點(diǎn):

viewport

媒體查詢

字體單位

百分比布局

圖片自適應(yīng)

flex,grid,BFC,絕對(duì)布局等常用技巧

查看demo

查看源碼,歡迎star

你們的打賞是我寫作的動(dòng)力



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

轉(zhuǎn)載請(qǐng)注明本文地址:http://systransis.cn/yun/113699.html

相關(guān)文章

  • Are you sure you understand the responsive layout?

    摘要:我們推薦使用作為字體單位默認(rèn)情況下我們標(biāo)簽的為,我們可以利用媒體查詢,設(shè)置在不同設(shè)備下的字體大小百分比布局用過的同學(xué)都知道,它里面有個(gè)柵格系統(tǒng),說(shuō)白了就是利用百分比來(lái)定義我們?cè)貙捀撸恢苯邮褂谩? 曾幾何時(shí)我認(rèn)為使用了媒體查詢就是響應(yīng)式布局,這種理解實(shí)在是太淺薄了,今天就讓我們重新來(lái)認(rèn)識(shí)下什么是響應(yīng)式布局 查看demo 查看源碼,歡迎star 什么是響應(yīng)式布局 前幾年風(fēng)靡一時(shí)Boot...

    longshengwang 評(píng)論0 收藏0
  • [譯]CSS Grid, Flexbox 和 Box Alignment:網(wǎng)頁(yè)布局的新系統(tǒng)

    摘要:原文標(biāo)題原文鏈接在網(wǎng)頁(yè)上布局是很費(fèi)勁的。的新值和都是屬性的新值。再一次,很明顯地看到,布局有一些默認(rèn)的行為。在網(wǎng)格布局中我們可以看到相同的效果。在這種情況下,容器的高度由項(xiàng)的最大高度決定。我們可以將項(xiàng)按照列擺放而不是行。 原文標(biāo)題:CSS Grid, Flexbox And Box Alignment: Our New System For Web Layout 原文鏈接:https...

    Alan 評(píng)論0 收藏0
  • 從web現(xiàn)狀談及前端性能優(yōu)化

    摘要:從現(xiàn)狀談及性能優(yōu)化原文出處性能優(yōu)化指南如今網(wǎng)絡(luò)發(fā)展迅猛,這對(duì)我們構(gòu)建的互聯(lián)網(wǎng)平臺(tái)要求也更高。這就說(shuō)明,我們?cè)陂_發(fā)時(shí),并沒有站在用戶的角度上換位思考,更別談性能優(yōu)化。因此,我們可通過區(qū)分關(guān)鍵資源并調(diào)整加載的優(yōu)先級(jí)來(lái)實(shí)現(xiàn)性能優(yōu)化。 從web現(xiàn)狀談及性能優(yōu)化 原文出處:《Karolina Szczur: The State of the Web》 性能優(yōu)化指南The Internet is ...

    paney129 評(píng)論0 收藏0
  • 從web現(xiàn)狀談及前端性能優(yōu)化

    摘要:從現(xiàn)狀談及性能優(yōu)化原文出處性能優(yōu)化指南如今網(wǎng)絡(luò)發(fā)展迅猛,這對(duì)我們構(gòu)建的互聯(lián)網(wǎng)平臺(tái)要求也更高。這就說(shuō)明,我們?cè)陂_發(fā)時(shí),并沒有站在用戶的角度上換位思考,更別談性能優(yōu)化。因此,我們可通過區(qū)分關(guān)鍵資源并調(diào)整加載的優(yōu)先級(jí)來(lái)實(shí)現(xiàn)性能優(yōu)化。 從web現(xiàn)狀談及性能優(yōu)化 原文出處:《Karolina Szczur: The State of the Web》 性能優(yōu)化指南The Internet is ...

    young.li 評(píng)論0 收藏0

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

0條評(píng)論

最新活動(dòng)
閱讀需要支付1元查看
<