詳解移動(dòng)端HTML5頁(yè)面根據(jù)屏幕適配的四種方案
文章主要介紹了詳解移動(dòng)端h5頁(yè)面根據(jù)屏幕適配的四種方案,文中通過(guò)示例代碼介紹的非常詳細(xì),需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧。方法一:引入淘寶開源的可伸縮布局方案引...
文章主要介紹了詳解移動(dòng)端h5頁(yè)面根據(jù)屏幕適配的四種方案,文中通過(guò)示例代碼介紹的非常詳細(xì),需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧。
方法一:引入淘寶開源的可伸縮布局方案
引入淘寶開源的可伸縮布局方案:https://github.com/amfe/lib-flexible(此處可點(diǎn)擊)
淘寶的其實(shí)也和viewport的有點(diǎn)像,但是它主要是根據(jù)設(shè)備設(shè)備像素比設(shè)置scale的值,保持視口device-width始終等于設(shè)備物理像素,屏幕大小動(dòng)態(tài)計(jì)算根字體大小,具體是將屏幕劃分為10等分。這塊也可以直接用js實(shí)現(xiàn),后面會(huì)提到
具體引入和使用方法,移步github查看,非常詳細(xì)。
方法二:viewport 的使用
github里邊,有提到 viewport 的使用。我感覺這篇文章關(guān)于viewport 的介紹特別詳細(xì),包括比例、是否縮放等的屬性介紹特別的詳細(xì),雖然文章的內(nèi)容一大片的字看起來(lái)很多,但是請(qǐng)耐心看完,都是干貨能很好的讓你認(rèn)識(shí)viewport。如果比較著急,請(qǐng)繼續(xù)往下看總結(jié)圖吧
https://www.jb51.net/article/149140.htm(此處可點(diǎn)擊)
關(guān)于 viewport 的,這塊直接引用上面文章的內(nèi)容,我感覺也是最干脆最直接的總結(jié)了吧
方法三:使用js+viewport動(dòng)態(tài)設(shè)置手動(dòng)適配rem
我的編輯器是vscode,添加了插件cssrem自動(dòng)轉(zhuǎn)換
index.html
<!DOCTYPE html>
<html>
??<head>
????<meta charset="utf-8">
????<!-- <meta name="viewport" content="width=device-width,initial-scale=1.0"> -->
????<meta name="viewport" content="width=device-width,initial-scale=1.0,minimum-scale=1.0,maximum-scale=1.0,user-scalable=no" />
????<!-- 啟用360瀏覽器的極速模式(webkit) -->
????<meta name="renderer" content="webkit">
????<!-- 避免IE使用兼容模式 -->
????<meta http-equiv="X-UA-Compatible" content="IE=edge">
????<!-- 針對(duì)手持設(shè)備優(yōu)化,主要是針對(duì)一些老的不識(shí)別viewport的瀏覽器,比如黑莓 -->
????<meta name="HandheldFriendly" content="true">
????<!-- 微軟的老式瀏覽器 -->
????<meta name="MobileOptimized" content="320">
????<!-- uc強(qiáng)制豎屏 -->
????<meta name="screen-orientation" content="portrait">
????<!-- QQ強(qiáng)制豎屏 -->
????<meta name="x5-orientation" content="portrait">
????<!-- UC強(qiáng)制全屏 -->
????<meta name="full-screen" content="yes">
????<!-- QQ強(qiáng)制全屏 -->
????<meta name="x5-fullscreen" content="true">
????<!-- UC應(yīng)用模式 -->
????<meta name="browsermode" content="application">
????<!-- QQ應(yīng)用模式 -->
????<meta name="x5-page-mode" content="app">
????<!-- windows phone 點(diǎn)擊無(wú)高光 -->
????<meta name="msapplication-tap-highlight" content="no">
????<meta content="telephone=no" name="format-detection" />
????<meta name="huaban" content="nopin" />
????<link rel="icon" type="image/x-icon" href="/favicon.ico">
????<title>新茶飲</title>
????<script src="/config.js"></script>
???<script src="http://res.wx.qq.com/open/js/jweixin-1.0.0.js"></script>
??</head>
??<body>
????<div id="app"></div>
????<!--
????在iPhone 5 中1rem=16px;
????html font-size =16px=1rem;
??-->
??<script>
????//得到手機(jī)屏幕的寬度
????let htmlWidth = document.documentElement.clientWidth || document.body.clientWidth;
????console.log('htmlWidth',htmlWidth)
????//得到html的Dom元素
????let htmlDom = document.getElementsByTagName('html')[0];
????// if(htmlWidth>640){//超過(guò)640大小的,字體根部都是16px
????//?? htmlWidth=640;
????//?? console.log('htmlWidth-true',htmlWidth)
????// }
????//設(shè)置根元素字體大小
????htmlDom.style.fontSize = htmlWidth / 40 + 'px';
?
??</script>
?????
??</body>
</html>
方法四:根據(jù)css的媒體查詢動(dòng)態(tài)設(shè)置根部html字體大小
html {font-size: 625%; /*100 ÷ 16 × 100% = 625%*/}
?
@media screen and (min-width:360px) and (max-width:374px) and (orientation:portrait) {
????html { font-size: 703%; }
}
@media screen and (min-width:375px) and (max-width:383px) and (orientation:portrait) {
????html { font-size: 732.4%; }
}
@media screen and (min-width:384px) and (max-width:399px) and (orientation:portrait) {
????html { font-size: 750%; }
}
@media screen and (min-width:400px) and (max-width:413px) and (orientation:portrait) {
????html { font-size: 781.25%; }
}
@media screen and (min-width:414px) and (max-width:431px) and (orientation:portrait){
????html { font-size: 808.6%; }
}
@media screen and (min-width:432px) and (max-width:479px) and (orientation:portrait){
????html { font-size: 843.75%; }
}
到此這篇關(guān)于詳解移動(dòng)端h5頁(yè)面根據(jù)屏幕適配的四種方案的文章就介紹到這了,更多相關(guān)h5移動(dòng)端根據(jù)屏幕適配內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章
- 基于HTML5+tracking.js實(shí)現(xiàn)刷臉支付功能
- html5 canvas 實(shí)現(xiàn)光線沿不規(guī)則路徑運(yùn)動(dòng)實(shí)例代碼
- html5中使用hotcss.js實(shí)現(xiàn)手機(jī)端自適配的方法
- HTML5網(wǎng)頁(yè)遮罩層 + Iframe實(shí)現(xiàn)界面自動(dòng)顯示的示例代碼
- HTML5通過(guò)navigator.mediaDevices.getUserMedia調(diào)用手
- HTML5中的網(wǎng)絡(luò)存儲(chǔ)實(shí)現(xiàn)方式
- HTML5離線存儲(chǔ)Manifest原理及使用詳解
- HTML5調(diào)用手機(jī)發(fā)短信和打電話功能
- HTML5標(biāo)簽HTMLCollection和NodeList的區(qū)別詳解
- HTML5網(wǎng)頁(yè)中iframe與window.onload如何使用詳解
基于HTML5+tracking.js實(shí)現(xiàn)刷臉支付功能
文章主要介紹了基于HTML5+tracking.js實(shí)現(xiàn)刷臉支付功能,本文通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),需要的朋友可以參考下...
html5 canvas 實(shí)現(xiàn)光線沿不規(guī)則路徑運(yùn)動(dòng)實(shí)例代碼
文章主要介紹了html5 canvas 實(shí)現(xiàn)光線沿不規(guī)則路徑運(yùn)動(dòng),本文通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),需要的朋友可以參考下。g讓動(dòng)畫沿著不規(guī)則路徑運(yùn)動(dòng)查閱svg文檔后發(fā)現(xiàn),svg動(dòng)畫...
html5中使用hotcss.js實(shí)現(xiàn)手機(jī)端自適配的方法
文章主要介紹了html5中使用hotcss.js實(shí)現(xiàn)手機(jī)端自適配的方法,本文通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),需要的朋友可以參考下Html5頁(yè)面在手機(jī)端做自適配是很常見的技術(shù)需求,下面...
HTML5網(wǎng)頁(yè)遮罩層 + Iframe實(shí)現(xiàn)界面自動(dòng)顯示的示例代碼
主要介紹了遮罩層 + Iframe實(shí)現(xiàn)界面自動(dòng)顯示的示例代碼,文中通過(guò)示例代碼介紹的非常詳細(xì),需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧前言這周由于科三的考試耽誤了兩天,提前一...
HTML5通過(guò)navigator.mediaDevices.getUserMedia調(diào)用手機(jī)攝像頭問(wèn)題
文章主要介紹了HTML5通過(guò)navigator.mediaDevices.getUserMedia調(diào)用手機(jī)攝像頭問(wèn)題,本文通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),需要的朋友可以參考下navigator.mediaDevices.getU...
HTML5中的網(wǎng)絡(luò)存儲(chǔ)實(shí)現(xiàn)方式
傳統(tǒng)方式使用document.cookie來(lái)進(jìn)行存儲(chǔ),但是由于其存儲(chǔ)的空間只有4KB左右,并且需要復(fù)雜的操作進(jìn)行解析,給發(fā)開者帶來(lái)很多不便,為此,HTML5規(guī)范提出了網(wǎng)絡(luò)存儲(chǔ)的解決方案,本文通過(guò)...
HTML5離線存儲(chǔ)Manifest原理及使用詳解
文章主要介紹了H5離線存儲(chǔ)Manifest原理及使用,文中通過(guò)示例代碼介紹的非常詳細(xì),需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧理解:離線存儲(chǔ)可以將站點(diǎn)的文件儲(chǔ)存在本地,在沒有網(wǎng)絡(luò)...
HTML5調(diào)用手機(jī)發(fā)短信和打電話功能
文章主要介紹了HTML5調(diào)用手機(jī)發(fā)短信和打電話功能,本文通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),需要的朋友可以參考下前言本來(lái)感覺用H5寫調(diào)用電話撥號(hào)功能和發(fā)送短信功能會(huì)很不好寫...
HTML5標(biāo)簽HTMLCollection和NodeList的區(qū)別詳解
文章主要介紹了HTML5中的HTMLCollection和NodeList的區(qū)別詳解,文中通過(guò)示例代碼介紹的非常詳細(xì),需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧HTML5 HTMLCollection和NodeList的...
HTML5網(wǎng)頁(yè)中iframe與window.onload如何使用詳解
文章主要介紹了iframe與window.onload如何使用詳解,文中通過(guò)示例代碼介紹的非常詳細(xì),需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧。前言在項(xiàng)目上,需要等頁(yè)面加載完之后再執(zhí)行一...