vue移動(dòng)端html5頁(yè)面根據(jù)屏幕適配的四種解決方法
最近做了兩個(gè)關(guān)于h5頁(yè)面對(duì)接公眾號(hào)的項(xiàng)目,不得不提打開(kāi)微信瀏覽器內(nèi)置地圖導(dǎo)航的功能確實(shí)有點(diǎn)惡心。下次想起來(lái)了的話,進(jìn)行總結(jié)分享一下如何處理。在vue移動(dòng)端h5頁(yè)面當(dāng)中,其中適配是經(jīng)常會(huì)遇到的問(wèn)題,這塊主要有死個(gè)方法可以適用。
方法一:引入淘寶開(kāi)源的可伸縮布局方案
引入淘寶開(kāi)源的可伸縮布局方案: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 的使用。我感覺(jué)這篇文章關(guān)于viewport 的介紹特別詳細(xì),包括比例、是否縮放等的屬性介紹特別的詳細(xì),雖然文章的內(nèi)容一大片的字看起來(lái)很多,但是請(qǐng)耐心看完,都是干貨能很好的讓你認(rèn)識(shí)viewport。如果比較著急,請(qǐng)繼續(xù)往下看總結(jié)圖吧
http://chabaoo.cn/article/149140.htm
關(guān)于 viewport 的,這塊直接引用上面文章的內(nèi)容,我感覺(jué)也是最干脆最直接的總結(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" rel="external nofollow" >
<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的媒體查詢(xún)動(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%; }
}
總結(jié)
以上所述是小編給大家介紹的vue移動(dòng)端html5頁(yè)面根據(jù)屏幕適配的四種解決方法,希望對(duì)大家有所幫助,如果大家有任何疑問(wèn)請(qǐng)給我留言,小編會(huì)及時(shí)回復(fù)大家的。在此也非常感謝大家對(duì)腳本之家網(wǎng)站的支持!
相關(guān)文章
前端vue3項(xiàng)目中百度地圖的使用api以及操作實(shí)例
最近項(xiàng)目要用到百度地圖api,好久沒(méi)用到地圖,就百度了一番,但是找了好幾篇文章,發(fā)現(xiàn)都沒(méi)辦法成功實(shí)現(xiàn),現(xiàn)將方法記錄如下,下面這篇文章主要給大家介紹了關(guān)于前端vue3項(xiàng)目中百度地圖的使用api以及操作實(shí)例,需要的朋友可以參考下2023-05-05
vue使用jsencrypt實(shí)現(xiàn)rsa前端加密的操作代碼
這篇文章主要介紹了vue使用jsencrypt實(shí)現(xiàn)rsa前端加密,本文通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2023-09-09
Vue前端利用slice()方法實(shí)現(xiàn)分頁(yè)器
分頁(yè)功能是常見(jiàn)的需求之一,本文主要介紹了Vue前端利用slice()方法實(shí)現(xiàn)分頁(yè)器,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2023-07-07
vue樹(shù)形結(jié)構(gòu)數(shù)據(jù)處理的方法總結(jié)
在項(xiàng)目開(kāi)發(fā)的過(guò)程中,會(huì)經(jīng)常使用樹(shù)形結(jié)構(gòu)數(shù)據(jù),前后端交互都會(huì)對(duì)數(shù)據(jù)進(jìn)行處理,后端返回的數(shù)據(jù)前端有的時(shí)候不能直接使用需要轉(zhuǎn)換,本文小編整理了一些項(xiàng)目中用到的處理方法,需要的朋友可以參考下2023-11-11
vue 界面刷新數(shù)據(jù)被清除 localStorage的使用詳解
今天小編就為大家分享一篇vue 界面刷新數(shù)據(jù)被清除 localStorage的使用詳解,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2018-09-09

