97免费在线观看视频 I 午夜夫妻视频 I 久久久久久网站 I 天堂网男人 I 欧美大波大乳人奶 I 丝袜 中出 制服 人妻 美腿 I 窝窝午夜理论片影院 I 日韩在线伦理电影 I 韩国特级毛片 I 亚洲欧美另类激情 I 在线成人日韩 I 麻豆视频免费看 I 黄色生活毛片 I 极品一线天小嫩嫩真紧 I 色久天堂 I 久久久久久黄色片 I 林智妍三级露全乳电影视频 I 大肉大捧一进一出好爽视频 I 空乘伦理hd I 少妇口述与子做过爱 I 成人免费影片 I 国产精品国内免费一区二区三区 I 日韩制服一区 I 青青草福利在线 I 日本在线观看不卡视频 I 婷婷六月综合亚洲 I 国产又粗又黄又硬 I 美女扒开屁股让男子桶爽 I 欧美性午夜视频观看 I 欧美狠狠插 I 亚洲福利在线观看视频 I 无码抽搐高潮喷水流白浆 I 亚洲欧美国产日韩色伦 I 你懂的视频网站在线观看 I www.蜜桃视频在线观看 I 日本无码人妻精品一区二区蜜桃 I 久久中文字幕人妻丝袜 I 碰草在线视频 I 日韩精品成人av网站

移動端適配方案具體實現(xiàn)以及對比

2020/11/27 18:00:01   閱讀:6686    發(fā)布者:6686
  • media queries
  • flex 布局
  • rem + viewport
  • vh vw
  • 百分比
  • bootstrap

一、Meida Queries

meida queries 的方式可以說是我早期采用的布局方式,它主要是通過查詢設(shè)備的寬度來執(zhí)行不同的 css 代碼,最終達到界面的配置。


二、Flex 彈性布局

以天貓的實現(xiàn)方式進行說明:
它的 viewport 是固定的:<meta name="viewport" content="width=device-width,initial-scale=1,maximum-scale=1,user-scalable=no">
高度定死,寬度自適應(yīng),元素都采用 px 做單位。
隨著屏幕寬度變化,頁面也會跟著變化,效果就和 PC 頁面的流體布局差不多,在哪個寬度需要調(diào)整的時候使用響應(yīng)式布局調(diào)

三、rem+viewport 縮放

實現(xiàn)原理:
根據(jù) rem 將頁面放大 dpr 倍, 然后 viewport 設(shè)置為 1/dpr.

如 iphone6 plus 的 dpr 為 3, 則頁面整體放大 3 倍, 1px(css 單位)在 plus 下默認為 3px(物理像素)
然后 viewport 設(shè)置為 1/3, 這樣頁面整體縮回原始大小. 從而實現(xiàn)高清。

這樣整個網(wǎng)頁在設(shè)備內(nèi)顯示時的頁面寬度就會等于設(shè)備邏輯像素大小,也就是 device-width。這個 device-width 的計算公式為:
設(shè)備的物理分辨率/(devicePixelRatio * scale),在 scale 為 1 的情況下,device-width = 設(shè)備的物理分辨率/devicePixelRatio。

四、rem 實現(xiàn)

rem是相對長度單位,rem方案中的樣式設(shè)計為相對于根元素font-size計算值的倍數(shù)。根據(jù)屏幕寬度設(shè)置html標簽的font-size,在布局時使用 rem 單位布局,達到自適應(yīng)的目的。
viewport 是固定的:<meta name="viewport" content="width=device-width,initial-scale=1,maximum-scale=1,user-scalable=no">。

五、純 vw 方案


視口是瀏覽器中用于呈現(xiàn)網(wǎng)頁的區(qū)域。

vw : 1vw 等于 視口寬度 的 1%
vh : 1vh  等于 視口高度 的 **1% **
vmin : 選取 vw 和 vh 中 最小 的那個
vmax : 選取 vw 和 vh 中 最大 的那個

六、vw + rem 方案

// scss 語法
// 設(shè)置html根元素的大小 750px->75 640px->64
// 將屏幕分成10份,每份作為根元素的大小。
$vw_fontsize: 75
@function rem($px) {
    // 例如:一個div的寬度為100px,那么它對應(yīng)的rem單位就是(100/根元素的大小)* 1rem
    @return ($px / $vw_fontsize) * 1rem;
}
$base_design: 750
html {
    // rem與vw相關(guān)聯(lián)
    font-size: ($vw_fontsize / ($base_design / 2)) * 100vw;
    // 同時,通過Media Queries 限制根元素最大最小值
    @media screen and (max-width: 320px) {
        font-size: 64px;
    }
    @media screen and (min-width: 540px) {
        font-size: 108px;
    }
}

// body 也增加最大最小寬度限制,避免默認100%寬度的 block 元素跟隨 body 而過大過小
body {
    max-width: 540px;
    min-width: 320px;
}

七、百分比

使用百分比%定義寬度,高度用px固定,根據(jù)可視區(qū)域?qū)崟r尺寸進行調(diào)整,盡可能適應(yīng)各種分辨率,通常使用max-width/min-width控制尺寸范圍過大或者過小。