婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁 > 知識(shí)庫 > html5 分層屏幕適配的方法

html5 分層屏幕適配的方法

熱門標(biāo)簽:ai電銷機(jī)器人連接網(wǎng)關(guān) 濟(jì)南辦理400電話 漳州人工外呼系統(tǒng)排名 鶴壁手機(jī)自動(dòng)外呼系統(tǒng)怎么安裝 威海營銷外呼系統(tǒng)招商 鄭州電銷外呼系統(tǒng)違法嗎 中紳電銷智能機(jī)器人 農(nóng)村住宅地圖標(biāo)注 跟電銷機(jī)器人做同事

設(shè)計(jì)大大,這次真的是 "按設(shè)計(jì)稿來" 了,因?yàn)楝F(xiàn)在,任何機(jī)子都是設(shè)計(jì)稿標(biāo)準(zhǔn)機(jī)! 開發(fā)同學(xué),這下你就直接讀設(shè)計(jì)稿標(biāo)注就好了啦!

屏幕適配

屏幕適配應(yīng)當(dāng)指內(nèi)容 適配區(qū) 和 屏幕區(qū) 間的適配關(guān)系。

單屏適配有 contain、cover 或 fill,多屏常見是 依寬 。

contain 和 cover 還需要 定位 來處理留白和超出的內(nèi)容。

而同一個(gè) H5 里不同內(nèi)容往往用不同適配方式,即 分層。

優(yōu)選CSS

  1. 頁面加載后 js 往往需要延時(shí)至少 70ms 才能獲取正確的 webview 寬高
  2. css 往往最先執(zhí)行,且 cssom 的解析往往和 dom 在最開始并行構(gòu)建
  3. js 會(huì)等待 dom 和 cssom 處理完后才能執(zhí)行,而 css 只需等待 dom
  4. 相比 js 在切換橫豎屏?xí)r要切換 2 次進(jìn)程來重繪,css 無需切換

對(duì)于屏幕適配這類表現(xiàn)問題,能用 css 實(shí)現(xiàn)就應(yīng)該用 css 實(shí)現(xiàn)。

整層適配

為確保各層元素同步縮放,不走樣,每層的 適配區(qū) 應(yīng)當(dāng)?shù)扔谠O(shè)計(jì)稿大小。

直接的實(shí)現(xiàn)就是構(gòu)造和 適配區(qū) 一樣尺寸的 容器, 整層適配。

容器 內(nèi)可以有若干個(gè)相同適配方式的 元素。

svg 實(shí)現(xiàn)為例:

<!doctype html>
<html>
<body>
<style>
.layer {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}
</style>
<!-- fill -->
<svg class="layer" viewBox="0 0 1080 1920" preserveAspectRatio="none"> <!-- 容器 -->
  <rect x="0" y="0" width="1080" height="1920" fill="rgba(96,96,96,.08)"/>  <!-- 元素 -->
</svg>
<!-- contain 居中 -->
<svg class="layer" viewBox="0 0 1080 1920" preserveAspectRatio="xMidYMid meet"> <!-- 容器 -->
  <rect x="0" y="233" width="1080" height="1407" fill="#1565C0"/>  <!-- 元素 -->
</svg>
<!-- contain 居底 -->
<svg class="layer" viewBox="0 0 1080 1920" preserveAspectRatio="xMidYMax meet"> <!-- 容器 -->
  <rect x="444" y="1779" width="191" height="39" fill="#1565C0"/>  <!-- 元素 -->
</svg>
</body>
</html>

實(shí)際效果:

整層適配 實(shí)現(xiàn)簡單,開發(fā)時(shí)直接讀取設(shè)計(jì)稿值,可以滿足大部分靜態(tài)頁面需求。

但在 h5 動(dòng)畫多的時(shí)候,就得考慮動(dòng)畫流暢,頁面性能了。

用可替換元素如 <img> <object> <svg> 等做 容器,以及用背景圖做 元素 的,

在應(yīng)用 css 動(dòng)畫時(shí)有性能缺陷:

  1. 對(duì) 容器 內(nèi) 元素 應(yīng)用 css 動(dòng)畫會(huì)造成頻繁重排和重繪,導(dǎo)致卡頓。
  2. 將和 適配區(qū) 尺寸相同的 容器 提升為合成層時(shí)所占內(nèi)存過大,有多少層內(nèi)存就翻多少倍。

為這些實(shí)現(xiàn)方案提升性能就要針對(duì) 容器 動(dòng)畫,并減小 容器 的尺寸,最好是和一層里所有 元素 的最小總面積相等,做到 精簡適配

精簡適配

公式

推導(dǎo)過程見 H5 分層屏幕適配公式推導(dǎo)

設(shè)計(jì)稿
  寬 v
  高 g
  
適配前元素
  橫坐標(biāo) x
  縱坐標(biāo) y
  寬 w
  高 h

適配后容器
  橫坐標(biāo) x3 = x*u/v
  縱坐標(biāo) y3 = y*f/g

適配后元素
  橫坐標(biāo) x4 = m*u + (x - m*v)/w*w1 = m*v/w*w3 + (x - m*v)/w*w1
  縱坐標(biāo) y4 = n*f + (y - n*g)/h*h1 = n*g/h*h3 + (y - n*g)/h*h1
  寬 w3 = (w/v)*u
  高 h3 = (h/g)*f
  當(dāng) contain 方式適配時(shí)
    縮放值 s = Math.min(f/g, u/v)
    橫向左留白占總留白 o = (m*v - x)/w
    縱向上留白占總留白 p =  (n*g - y)/h
  當(dāng) cover 方式適配時(shí)
    縮放值 s = Math.max(f/g, u/v)
    橫向左超出占總超出 o = (x - m*v)/w
    縱向上超出占總超出 p =  (y - n*g)/h

適配區(qū)
  垂直居頂時(shí) m = 0
  垂直居中時(shí) m = .5
  垂直居底時(shí) m = 1 
  水平居左時(shí) n = 0
  水平居中時(shí) n = .5
  水平居右時(shí) n = 1 

相比整層適配內(nèi)存優(yōu)化 (w3*h3)/(v1*g1) >= w*h/(v*g)

<img> 實(shí)現(xiàn)示例
當(dāng)設(shè) max-width 為 w/v,max-height 為 h/g 時(shí)對(duì)應(yīng) contain 適配。
當(dāng)設(shè) min-width 為 w/v,min-height 為 h/g 時(shí)對(duì)應(yīng) cover 適配。
當(dāng)設(shè) width 為 w/v,height 為 h/g 時(shí)表示 fill 適配。
contain 適配時(shí),如果圖片原始尺寸小于 max-width 和 max-height 時(shí),用 zoom: 10 放大或者直接修改圖片原始尺寸。
cover 適配時(shí),如果圖片原始尺寸大于 min-width 和 min-height 時(shí),用 zoom: .1 縮小或者直接修改圖片原始尺寸。
因 top left 中百分比是相對(duì)屏幕寬 u 和高 f 的,對(duì)應(yīng) m*u 和 n*f
因 transform 中百分比是相對(duì)適配后元素寬 w1 和高 h1 的,對(duì)應(yīng) (m*v + x)/w*w1 和 (n*f + y)/h*h1

<!doctype html>
<html>
<body>
<style>
img {
  /* min-width 和 min-height 構(gòu)成了虛擬的容器 */
  min-width: 50.37037037037037%; /* w3 = (w/v)*u 其中 w = 544,v = 1080 */
  min-height: 7.395833333333333%; /* h3 = (h/g)*f 其中 h = 142,g = 1920 */
  zoom: .1;
  /* x4 = m*u + (x - m*v)/w*w1 */
  /* y4 = n*f + (y - n*g)/h*h1 */
  position: absolute;
  left: 50%; /* m*u 其中 m = .5*/
  top: 50%; /* n*f 其中 n = .5 */
  transform:
    translateX(-48.34558823529412%) /* (x - m*v)/w*w1 其中 x = 277,m = .5,v = 1080,w = 544 */
    translateY(378.8732394366197%); /* (y - n*g)/h*h1 其中 y = 1498,n = .5,g = 1920,h = 142 */
}
</style>
<img src="http://ui.qzone.com/544x142"/> <!-- 元素 -->
</body>
</html>

background 實(shí)現(xiàn)示例

  1. background-size 值為 contain 時(shí)對(duì)應(yīng) contain 適配。
  2. background-size 值為 cover 時(shí)對(duì)應(yīng) cover 適配。
  3. background-size 值為 100% 100% 時(shí)對(duì)應(yīng) `fill 適配。
  4. background-position 百分比和 o p 意義相同
<!doctype html>
<html>
<body>
<style>
div {
  position: absolute;
  width: 50.37037037037037%; /* w3 = w/v*u 其中 w = 544,v = 1080 */
  height: 7.395833333333333%; /* h3 = h/g*f 其中 h = 142,g = 1920 */
  background: url(http://ui.qzone.com/544x142) no-repeat; /* 背景圖做元素 */
  background-size: cover;
  left: 25.64814814814815%; /* x3 = x/v*u 其中 x = 277, v = 1080 */
  top: 78.02083333333333%; /* y3 = y/g*f 其中 y = 1498, g = 1920 */
  background-position-x: -48.34558823529412%; /* o = (x - m*v)/w 其中 m = .5 , v = 1080,x = 277,w = 544*/
  background-position-y: 378.8732394366197%; /* p = (y - n*g)/h 其中 n = .5 , g = 1920,y = 1498,h = 142*/
}
</style>
<div></div> <!-- 容器 -->
</body>
</html>

<svg> 實(shí)現(xiàn)示例

  1. preserveAspectRatiomeetOrSlicemeet 時(shí)對(duì)應(yīng) contain 適配。
  2. preserveAspectRatiomeetOrSliceslice 時(shí)對(duì)應(yīng) cover 適配。
  3. preserveAspectRatio 值為 none 時(shí)對(duì)應(yīng) fill 適配。
  4. 這里 preserveAspectRatiomeetOrSlice 相對(duì)的是容器,不是 適配區(qū) 這里用 transform 來定位,而 preserveAspectRatiomeetOrSlice 固定為 xMinYMin。
<!doctype html>
<html>
<body>
<style>
svg {
  position: absolute;
  width: 50.37037037037037%;
  height: 7.395833333333333%;
  /* x4 = m*v/w*w3 + (x - m*v)/w*w1 */
  /* y4 = n*g/h*h3 + (y - n*g)/h*h1 */
  top: 0;
  left: 0;
  transform:
    translateX(99.26470588235294%) /* m*v/w*w3 其中 m = .5,v = 1080,w = 544 */
    translateY(676.056338028169%); /* n*g/h*h3 其中 n = .5,g = 1920,h = 142 */
    overflow: visible;
}
svg image {
  transform:
    translateX(-48.34558823529412%) /* (x - m*v)/w*w1 其中 x = 277,m = .5,v = 1080,w = 544 */
    translateY(378.8732394366197%); /* (y - n*g)/h*h1 其中 y = 1498,n = .5,g = 1920,h = 142 */
}
</style>
<svg viewBox="0 0 544 142" preserveAspectRatio="xMinYMin meet"> <!-- 容器 -->
  <image width="544" height="142" xlink:href="http://ui.qzone.com/544x142"/> <!-- 元素 -->
</svg>
</body>
</html>

輔助工具

手動(dòng)計(jì)算百分比及寫 css 很麻煩,可以借助 sass 等工具來輔助簡化。
設(shè)計(jì)稿寬 vg 一般是頁面級(jí)常量。
只需讀取設(shè)計(jì)稿里每個(gè) 元素 的橫坐標(biāo) x 、縱坐標(biāo) y 、寬 w 和 高 h,然后工具生成 css 即可。
這下媽媽再也不用擔(dān)心我還原問題、屏幕適配問題了。

文字處理

文字固定或單行不固定,svgtext 標(biāo)簽可以處理

文字固定或單行不固定還可以將文字轉(zhuǎn)為圖片

文字多行不固定,可以借助 svgforeignObject 嵌入普通 div

方案對(duì)比

屏幕適配方案非常多,選哪種方式實(shí)現(xiàn) 整層適配 或 精簡適配,下面是對(duì)比

方案 縮放 定位 文字縮放 兼容
padding-top 百分比 只能依寬
viewport 支持情況復(fù)雜
object-fit 移動(dòng)端 android 4.4.4+
svg preserveRatio 移動(dòng)端 android 3.0+
(max/min)-(width/height) 固定文字
background-size 文字轉(zhuǎn)圖片

以上就是本文的全部內(nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

標(biāo)簽:甘南 惠州 紅河 文山 蘇州 咸陽 營口 萍鄉(xiāng)

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《html5 分層屏幕適配的方法》,本文關(guān)鍵詞  html5,分層,屏幕,適配,的,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《html5 分層屏幕適配的方法》相關(guān)的同類信息!
  • 本頁收集關(guān)于html5 分層屏幕適配的方法的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av
    亚洲三级在线免费| 国产传媒一区在线| 午夜日韩在线电影| 亚洲精品国产视频| 中文字幕在线视频一区| 欧美激情一区二区三区四区| 欧美精品一区二区三区一线天视频| 制服.丝袜.亚洲.中文.综合| 欧美亚洲动漫制服丝袜| 欧美日韩专区在线| 宅男在线国产精品| 日韩欧美激情四射| 久久这里只精品最新地址| 日韩欧美一级在线播放| 日韩午夜激情av| 久久亚洲二区三区| 国产精品高潮久久久久无| 亚洲精品videosex极品| 亚洲国产精品人人做人人爽| 五月天视频一区| 捆绑调教美女网站视频一区| 国产风韵犹存在线视精品| 豆国产96在线|亚洲| 97se狠狠狠综合亚洲狠狠| 色吊一区二区三区| 88在线观看91蜜桃国自产| 精品免费99久久| 国产精品毛片久久久久久久| 一区二区三区av电影| 日韩和欧美的一区| 国产精品中文字幕欧美| 色综合久久综合网欧美综合网| 欧美视频中文字幕| 日韩欧美一级片| 国产精品网曝门| 亚洲精品成人a在线观看| 日韩国产在线一| 国产美女娇喘av呻吟久久| 99久久伊人精品| 欧美三级视频在线| 久久亚区不卡日本| 亚洲第一主播视频| 国产激情一区二区三区四区| 色哟哟精品一区| 日韩美女主播在线视频一区二区三区 | 亚洲自拍另类综合| 毛片一区二区三区| 懂色一区二区三区免费观看| 欧美亚洲自拍偷拍| 欧美精品一区二区精品网| 亚洲日本va午夜在线影院| 青青草原综合久久大伊人精品| 国产大片一区二区| 欧美老人xxxx18| 国产精品五月天| 蜜臀精品一区二区三区在线观看| 国产成人亚洲精品青草天美| 欧美亚洲综合久久| 国产精品久久久一区麻豆最新章节| 一区二区欧美精品| 成人午夜在线视频| 欧美成人综合网站| 亚洲最大成人网4388xx| 国产99久久久国产精品| 91麻豆精品国产91久久久| 亚洲乱码一区二区三区在线观看| 麻豆国产一区二区| 欧美色视频在线| 国产精品毛片久久久久久久| 精品一区二区精品| 欧美日本国产视频| 一区二区三区四区亚洲| 国产99久久久精品| 久久综合久久综合亚洲| 午夜私人影院久久久久| 91丨九色丨国产丨porny| 中文字幕乱码日本亚洲一区二区 | 国产老肥熟一区二区三区| 欧美伊人久久久久久午夜久久久久| 久久九九久精品国产免费直播| 五月激情六月综合| 91精品91久久久中77777| 成人免费一区二区三区在线观看 | 日本丰满少妇一区二区三区| 中文字幕欧美国产| 国产福利精品导航| 精品国产一区二区三区忘忧草| 午夜视频在线观看一区| 欧美日韩卡一卡二| 亚洲国产成人va在线观看天堂| 9人人澡人人爽人人精品| 国产日产欧美一区二区视频| 激情综合五月天| 欧美一级理论片| 日本在线不卡视频一二三区| 欧美精品黑人性xxxx| 午夜视频在线观看一区二区三区 | 亚洲永久精品国产| 色综合 综合色| 亚洲精品视频观看| 日本精品裸体写真集在线观看| 亚洲欧美日韩综合aⅴ视频| 91在线视频免费91| 亚洲精品免费看| 欧美网站大全在线观看| 亚洲成人7777| 777午夜精品免费视频| 首页亚洲欧美制服丝腿| 欧美一区二区三区思思人| 麻豆91免费观看| 日韩欧美高清dvd碟片| 极品少妇xxxx精品少妇偷拍| 精品国产乱码久久久久久夜甘婷婷| 久久国产日韩欧美精品| 久久一夜天堂av一区二区三区| 韩国理伦片一区二区三区在线播放| 欧美mv和日韩mv的网站| 国产激情一区二区三区四区| 国产精品对白交换视频| 色就色 综合激情| 亚洲v精品v日韩v欧美v专区| 欧美日韩国产免费一区二区 | 成人的网站免费观看| 中文字幕亚洲区| 欧美体内she精高潮| 日韩av午夜在线观看| 欧美精品一区二区三区高清aⅴ| 国产v综合v亚洲欧| 一区二区三区日韩欧美精品 | 视频一区二区中文字幕| 精品欧美黑人一区二区三区| 国产91露脸合集magnet| 亚洲精品乱码久久久久久日本蜜臀| 欧美羞羞免费网站| 久久精品国产在热久久| 日本一区二区视频在线| 色激情天天射综合网| 男人的天堂亚洲一区| 国产精品网站一区| 在线播放一区二区三区| 国产不卡免费视频| 亚洲国产精品一区二区www| 欧美成人激情免费网| 91在线免费看| 蜜桃av一区二区三区| 国产精品久久久久永久免费观看 | 欧美丰满高潮xxxx喷水动漫| 国产在线播放一区| 亚洲精品免费在线| 2021国产精品久久精品| 99久久婷婷国产| 久久精品国产网站| 亚洲色图欧美在线| 精品少妇一区二区| 欧美亚洲一区二区在线| 国产乱码精品一区二区三区av| 一区二区三区四区av| 久久老女人爱爱| 欧美精品一级二级| 91在线观看下载| 麻豆91在线看| 亚洲成av人片一区二区梦乃| 国产免费成人在线视频| 91精品国产综合久久福利| 成人永久免费视频| 蜜桃av噜噜一区| 亚洲综合一区在线| 国产精品网站在线观看| 精品国产91洋老外米糕| 欧美色图12p| 91视频精品在这里| 国产成人在线观看免费网站| 日本va欧美va瓶| 亚洲成av人片| 亚洲免费av高清| 中文在线资源观看网站视频免费不卡 | 在线视频你懂得一区二区三区| 国产精品一级黄| 男女视频一区二区| 性做久久久久久| 亚洲免费观看视频| 国产精品久久久一区麻豆最新章节| 欧美成人精品福利| 日韩欧美国产一区在线观看| 欧美日韩一区二区在线视频| 91蜜桃视频在线| 9色porny自拍视频一区二区| 国产精品白丝jk黑袜喷水| 老司机午夜精品| 蜜桃精品视频在线观看| 性做久久久久久免费观看| 亚洲国产欧美在线| 亚洲综合在线视频| 一区二区在线电影| 亚洲精品视频自拍| 一区二区三区资源| 亚洲激情男女视频| 一区二区三区中文字幕电影| 最新欧美精品一区二区三区| 亚洲视频每日更新|