主頁 > 知識庫 > HTML5 移動頁面自適應(yīng)手機屏幕寬度詳解

HTML5 移動頁面自適應(yīng)手機屏幕寬度詳解

熱門標(biāo)簽:滄州智能外呼系統(tǒng)收費 嘟聲的電銷機器人 電銷機器人怎么收費 地圖標(biāo)注和圖片標(biāo)注 洛陽便宜外呼系統(tǒng)廠家 湖北穩(wěn)定外呼系統(tǒng) 忻州外呼系統(tǒng)接口對接 語音平臺系統(tǒng) 醫(yī)院地圖標(biāo)注

網(wǎng)上關(guān)于這方面的文章有很多,重復(fù)的東西本文不再贅述,僅提供思路,并解釋一些其他文章講述模糊的地方。 

1、使用meta標(biāo)簽,這也是普遍使用的方法,理論上講使用這個標(biāo)簽是可以適應(yīng)所有尺寸的屏幕的,但是各設(shè)備對該標(biāo)簽的解釋方式及支持程度不同造成了不能兼容所有瀏覽器或系統(tǒng)。

首先解釋該標(biāo)簽的含義:

meta name="viewport" content="width=device-width,initial-scale=1.0, minimum-scale=1.0, maximum-scale=1.0, user-scalable=no"/>

如果你完全不了解這個標(biāo)簽的使用需要先百度一下。

解釋:content中的“width” 這個width指的是什么寬度,我看過的文章對這個都沒有解釋的很清楚,有幾個備選:虛擬窗口的寬度、手機屏幕的寬度、還是頁面的寬度等等?經(jīng)試驗這個指的是虛擬窗口的寬度。了解寬度之后,對后續(xù)的各種scale,就應(yīng)該知道是誰與誰的比例,是 虛擬窗口寬度 / 頁面寬度,這樣就會有問題出現(xiàn)安卓設(shè)備尺寸差異很大光主流的就有寬度為 320 480 720 1080 等各種尺寸而以上標(biāo)簽只能支持一種尺寸,當(dāng)然有些瀏覽器會自動縮放使其適應(yīng)屏幕,但這不是統(tǒng)一標(biāo)準,正確的做法是用js動態(tài)生成此標(biāo)簽,當(dāng)然,應(yīng)該先獲取屏幕尺寸。

 script type="text/javascript">
    var phoneWidth = parseInt(window.screen.width);
    var phoneScale = phoneWidth/640;
    var ua = navigator.userAgent;
    if (/Android (\d+\.\d+)/.test(ua)){
      var version = parseFloat(RegExp.$1);
      if(version>2.3){
        document.write(‘meta name="viewport" content="width=640, minimum-scale = ‘+phoneScale+‘, maximum-scale = ‘+phoneScale+‘, target-densitydpi=device-dpi">‘);
      }else{
        document.write(‘meta name="viewport" content="width=640, target-densitydpi=device-dpi">‘);
      }
    } else {
      document.write(‘meta name="viewport" content="width=640, user-scalable=no, target-densitydpi=device-dpi">‘);
    }
  /script>
  

 對于此標(biāo)簽還有以下需要分享:

1)、user-scalable=no就一定可以保證頁面不可以縮放嗎?NO,有些瀏覽器不吃這一套,還有一招就是minimum-scale=1.0, maximum-scale=1.0 最大與最小縮放比例都設(shè)為1.0就可以了。

2)、initial-scale=1.0   初始縮放比例受user-scalable控制嗎?不一定,有些瀏覽器會將user-scalable理解為用戶手動縮放,如果user-scalable=no,initial-scale將無法生效。

3)、手機頁面可以觸摸移動,但是如果有需要禁止此操作,就是頁面寬度等于屏幕寬度是頁面正好適應(yīng)屏幕才可以保證頁面不能移動。

4)、如果頁面是經(jīng)過縮小適應(yīng)屏幕寬度的,會出現(xiàn)一個問題,當(dāng)文本框被激活(獲取焦點)時,頁面會放大至原來尺寸。

以上是使用viewport標(biāo)簽的一些小體會,分享給大家。

3、百分比法,首先應(yīng)明確一個概年,CSS中的百分比中的百指的是什么,我告訴你指的是父元素,所有百分比都是這樣的。子元素寬度50%,那么父元素的寬度就是百,子元素的padding-left:50%,父元素的寬度是百,子元素的margin-top:20%,那么父元素的高是百。所以body默認寬度是屏幕寬度(PC中指的是瀏覽器寬度)子孫元素按百分比定位(或指定尺寸)就可以了,這只適合布局簡單的頁面,復(fù)雜的頁面實現(xiàn)很困難。

4、使用css3單位rem,有人這樣解釋rem,root-em,就是根部的em,想必em大家都懂的,那么rem就是將根節(jié)點html的font-size的值作為整個頁面的基準尺寸,默認html的font-size是16px,即1rem=16px,如果某div寬度為32px你可以設(shè)為2rem。當(dāng)我們把html的font-size設(shè)為20px時,1rem=20px,那么32px=1.6rem了。到這里我們也就了解了rem的用法了,那么怎么用rem來實現(xiàn)不同尺寸屏幕的自適應(yīng)呢?在頁面載入開始時首先判斷window的寬度(是window的寬度($(window).width()),不是屏幕分辯率的寬度(screen.width),兩者的差別請自行查閱),假設(shè)寬度為W,一個div在寬度為640px的設(shè)計稿的下的寬度為dW1,這樣如果html的font-size為100px,那么這個div的寬度用rem表示是多少呢?計算:div寬度dW2=dW1/100,px與rem之間很好換算,除以100就可以,這是假定屏幕寬度為640的,而不同寬度的屏幕怎么處理,為了能保證換算容易那就要為html設(shè)置一個合適的font-size,計算:100 / 640 = fontSize / W, fontSize = W / 640 * 100 = W / 6.4;

解釋一下為什么把100作為一個縮放比例,用10或1不是更方便嗎,這是因為大多數(shù)瀏覽器font-size的最小值為12px,所以只能用100了。所以會在頭部加上這個JS代碼

script type="text/javascript">
  var html = document.querySelector(‘html‘);
  var rem = html.offsetWidth / 6.4;
  html.style.fontSize = rem + "px";
/script>
  

5、媒體查詢,媒體查詢也是css3的方法,我們要解決的問題是適應(yīng)手機屏幕,這個媒體查詢正是為解決這個問題而生,媒體查詢的功能就是為不同的媒體設(shè)置不同的css樣式,這里的“媒體”包括頁面尺寸,設(shè)備屏幕尺寸等,比如我們要為寬度小于480px的頁面中的class="icon"的元素設(shè)置樣式,可以這樣寫,@media screen and (max-width=480px) {.icon{ some styles }};這里僅介紹這種思路,關(guān)于媒體查詢的詳細用法請參閱css手冊。

綜上,至今,我沒有找到一種完全適應(yīng)各種屏幕的方法,只能根據(jù)頁面特點選擇不同的方法,多種方法靈活運用,才是王道。

通過此文,希望能幫助大家解決HTML5 自適應(yīng)手機屏幕寬度的問題,謝謝大家對本站的支持!

您可能感興趣的文章:
  • 微信小程序 圖片等比例縮放(圖片自適應(yīng)屏幕)
  • 4種Android屏幕自適應(yīng)解決方案
  • iOS Webview自適應(yīng)實際內(nèi)容高度的4種方法詳解
  • jQuery自適應(yīng)輪播圖插件Swiper用法示例
  • BootStrap table表格插件自適應(yīng)固定表頭(超好用)
  • jQuery簡單實現(xiàn)iframe的高度根據(jù)頁面內(nèi)容自適應(yīng)的方法
  • EasyUI布局 高度自適應(yīng)
  • JQuery EasyUI Layout 在from布局自適應(yīng)窗口大小的實現(xiàn)方法
  • jQuery實現(xiàn)布局高寬自適應(yīng)的簡單實例
  • 移動開發(fā)之自適應(yīng)手機屏幕寬度

標(biāo)簽:定州 日照 宜賓 山南 防城港 96 巴彥淖爾 內(nèi)蒙古

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《HTML5 移動頁面自適應(yīng)手機屏幕寬度詳解》,本文關(guān)鍵詞  HTML5,移動,頁面,自,適應(yīng),;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《HTML5 移動頁面自適應(yīng)手機屏幕寬度詳解》相關(guān)的同類信息!
  • 本頁收集關(guān)于HTML5 移動頁面自適應(yīng)手機屏幕寬度詳解的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章