溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點(diǎn)擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

移動(dòng)端h5頁面根據(jù)屏幕適配的示例分析

發(fā)布時(shí)間:2021-06-04 11:24:28 來源:億速云 閱讀:200 作者:小新 欄目:web開發(fā)

小編給大家分享一下移動(dòng)端h5頁面根據(jù)屏幕適配的示例分析,相信大部分人都還不怎么了解,因此分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后大有收獲,下面讓我們一起去了解一下吧!

方法一:引入淘寶開源的可伸縮布局方案

引入淘寶開源的可伸縮布局方案: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)容一大片的字看起來很多,但是請耐心看完,都是干貨能很好的讓你認(rèn)識(shí)viewport。如果比較著急,請繼續(xù)往下看總結(jié)圖吧

http://kemok4.com/article/149140.htm(此處可點(diǎn)擊)

關(guān)于 viewport 的,這塊直接引用上面文章的內(nèi)容,我感覺也是最干脆最直接的總結(jié)了吧

移動(dòng)端h5頁面根據(jù)屏幕適配的示例分析

方法三:使用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">
    <!-- 針對手持設(shè)備優(yōu)化,主要是針對一些老的不識(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)擊無高光 -->
    <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){//超過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 &divide; 16 &times; 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%; }
}

以上是“移動(dòng)端h5頁面根據(jù)屏幕適配的示例分析”這篇文章的所有內(nèi)容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內(nèi)容對大家有所幫助,如果還想學(xué)習(xí)更多知識(shí),歡迎關(guān)注億速云行業(yè)資訊頻道!

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI