欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

JavaScript實(shí)現(xiàn)移動端頁面按手機(jī)屏幕分辨率自動縮放的最強(qiáng)代碼

 更新時間:2017年08月18日 11:17:15   作者:蓓蕾心晴  
這篇文章主要介紹了JavaScript實(shí)現(xiàn)移動端頁面按手機(jī)屏幕分辨率自動縮放的最強(qiáng)代碼,通過阻止瀏覽器的默認(rèn)行為各方面分析縮放的功能實(shí)現(xiàn),具體操作步驟大家可查看下文的詳細(xì)講解,感興趣的小伙伴們可以參考一下。
 手機(jī)的屏幕有大有小,移動web最好做成響應(yīng)式布局,也就是自適應(yīng)屏幕,沒有固定寬高,這樣的話,在所有手機(jī)上都可以正常顯示。關(guān)于移動端頁面按手機(jī)屏幕分辨率自動縮放的js,先附上代碼
<script>
 var phoneWidth = parseInt(window.screen.width);
 var phoneHeight = parseInt(window.screen.height);
 var phoneScale = phoneWidth/750;//除以的值按手機(jī)的物理分辨率
 var ua = navigator.userAgent;
 if (/Android (\d+\.\d+)/.test(ua)) {
 var version = parseFloat(RegExp.$1);
 // andriod 2.3
 if (version > 2.3) {
 document.write('<meta name="viewport" content="width=device-width,initial-scale='+phoneScale+',minimum-scale='+phoneScale+',maximum-scale='+phoneScale+',user-scalable=no">');
 // andriod 2.3以上
 } else {
 document.write('<meta name="viewport" content="width=device-width,user-scalable=no">');
 }
 // 其他系統(tǒng)
 } else {
 document.write('<meta name="viewport" content="width=device-width, initial-scale='+phoneScale+',minimum-scale='+phoneScale+',maximum-scale ='+phoneScale +',user-scalable=no,">');
 }
</script>      

做手機(jī)端頁面最頭疼的就是物理分辨率和邏輯分辨率的轉(zhuǎn)換了,當(dāng)拿到設(shè)計圖的時候,圖基本都是按物理分辨率來設(shè)計的,一般常用的為640(iphone5/5s)、750(iphone6/6s),而谷歌等瀏覽器采用小手機(jī)模式瀏覽頁面的時候,上面的值為邏輯分辨率,調(diào)試的時候很難把控頁面樣式,在手機(jī)端的樣式也會因此大亂,在頁面頭部加入以上一段js之后,在手機(jī)端就可以正常顯示了,

var phoneScale = phoneWidth/750;

除以的為設(shè)計圖設(shè)計的頁面寬度,750是按iphone6來設(shè)計(根據(jù)自己使用需求來修改),即讓頁面的 放大比率=屏幕的邏輯分辨率/物理分辨率,從而達(dá)到適應(yīng)手機(jī)的效果。

(注意,有時候頁面加了這段代碼在調(diào)試的時候,切記刷新,刷新過后就會按手機(jī)縮放比例顯示)

概念解析:

phys.width:一般我們所指的寬度width即為phys.width,物理寬度(物理分辨率)

device-width:又稱為css-width,設(shè)備寬度(邏輯分辨率)

其中我們可以獲取phys.width通過document.documentElement.clientWidth;

而獲取css-width通過 window.screen.width獲取。

所以這里  phoneWidth(邏輯分辨率) = parseInt(window.screen.width);

如iphone6的phys.width為750px,而css-width為375px。

明白一個瀏覽器默認(rèn)行為。

試想,瀏覽器如果把電腦端的980px的網(wǎng)頁展現(xiàn)在寬度為750px的iphone6手機(jī)屏上,勢必會放不下,手機(jī)端橫向會出現(xiàn)滾動條,怎么阻止這種情況呢,很簡單,瀏覽器默認(rèn)一個虛擬窗口,不同瀏覽器有不同的虛擬窗口寬度的默認(rèn)值如:safari iphone:980px;

opera:850px;

Andriod webkit:800px;

IE:974px;

然后會把這個980px虛擬窗口裝進(jìn)寬度為750px的iphone6中,當(dāng)然這樣的話必須縮放,這就是為什么在手機(jī)中展現(xiàn)電腦端頁面沒有出現(xiàn)橫向滾動條,而且字跡明顯變小的原因。

initial-scale='+phoneScale+',minimum-scale='+phoneScale+',maximum-scale='+phoneScale+'

這段代碼切記要指定 initial-scale=***,在安卓系統(tǒng)中,不指定默認(rèn)的nitial-scale=***,只指定最小和最大縮放值,也可以正常顯示,但是safari瀏覽器則會失效,對于寬度是100%的頁面, 則顯示為頁面的30%左右的寬。

target-densitydpi=device-dpi

WebKit內(nèi)核默認(rèn)按照160的DPI來排版。假如設(shè)備真實(shí)DPI是480,寬度是1080,在WebKit會按160DPI,360寬度來排版。排版結(jié)束后在放大到1080寬。

所以當(dāng)取window.innerwidth之類的值的時候,取的是WebKit實(shí)際排版寬度360,而不是1080.

target-densitydpi=device-dpi可以強(qiáng)制內(nèi)核以480DPI排版,使畫面更精細(xì),window.innerwidth也將為屏幕寬度1080.

但WebKit從去年開始取消了對target-densitydpi的支持。(所以現(xiàn)在不建議寫該屬性了)

想實(shí)現(xiàn)target-densitydpi=device-dpi的效果有什么方法?提交此次補(bǔ)丁的WebKit開發(fā)者說可以用responsive images 和 CSS device units來替代。

參考鏈接:

http://www.dbjr.com.cn/article/121524.htm

http://www.dbjr.com.cn/article/121515.htm

以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對大家的學(xué)習(xí)或者工作能帶來一定的幫助~如果有疑問大家可以留言交流,謝謝大家對腳本之家的支持!

相關(guān)文章

  • 小程序列表懶加載的實(shí)現(xiàn)方式

    小程序列表懶加載的實(shí)現(xiàn)方式

    懶加載,前端人都知道的一種性能優(yōu)化方式,簡單的來說,只有當(dāng)圖片出現(xiàn)在瀏覽器的可視區(qū)域內(nèi)時,才設(shè)置圖片正真的路徑,讓圖片顯示出來,這篇文章主要給大家介紹了關(guān)于小程序列表懶加載的實(shí)現(xiàn)方式,需要的朋友可以參考下
    2022-04-04
  • 解決bootstrap-select 動態(tài)加載數(shù)據(jù)不顯示的問題

    解決bootstrap-select 動態(tài)加載數(shù)據(jù)不顯示的問題

    今天小編就為大家分享一篇解決bootstrap-select 動態(tài)加載數(shù)據(jù)不顯示的問題,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2018-08-08
  • 構(gòu)建一個JavaScript插件系統(tǒng)

    構(gòu)建一個JavaScript插件系統(tǒng)

    這篇文章主要介紹了如何構(gòu)建一個JavaScript插件系統(tǒng),幫助大家更好的理解和使用JavaScript,感興趣的朋友可以了解下
    2020-10-10
  • 淺談JS對象添加getter與setter的5種方法

    淺談JS對象添加getter與setter的5種方法

    這篇文章主要介紹了淺談 JS 對象添加 getter與 setter 的5種方法以及如何讓對象屬性不可配置或枚舉,需要的朋友可以參考下
    2018-06-06
  • js幾個不錯的函數(shù) $$()

    js幾個不錯的函數(shù) $$()

    js幾個不錯的函數(shù) $$()...
    2006-10-10
  • javascript實(shí)現(xiàn)平滑無縫滾動

    javascript實(shí)現(xiàn)平滑無縫滾動

    這篇文章主要為大家詳細(xì)介紹了javascript實(shí)現(xiàn)平滑無縫滾動的具體代碼,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2016-05-05
  • JavaScript SweetAlert插件實(shí)現(xiàn)超酷消息警告框

    JavaScript SweetAlert插件實(shí)現(xiàn)超酷消息警告框

    SweetAlert是一款使用純js制作的消息警告框插件.這篇文章主要介紹了JavaScript SweetAlert插件實(shí)現(xiàn)超酷消息警告框的相關(guān)資料,需要的朋友可以參考下
    2016-01-01
  • 淺談ES6 模板字符串的具體使用方法

    淺談ES6 模板字符串的具體使用方法

    本篇文章主要介紹了淺談ES6 模板字符串的具體使用方法,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-11-11
  • 完美實(shí)現(xiàn)八種js焦點(diǎn)輪播圖(上篇)

    完美實(shí)現(xiàn)八種js焦點(diǎn)輪播圖(上篇)

    這篇文章主要介紹了完美實(shí)現(xiàn)八種js焦點(diǎn)輪播圖的具體資料,基于完美運(yùn)動框架move2.js而完成的八種焦點(diǎn)錄播圖,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2016-07-07
  • JavaScript實(shí)現(xiàn)京東購物放大鏡和選項卡效果的方法分析

    JavaScript實(shí)現(xiàn)京東購物放大鏡和選項卡效果的方法分析

    這篇文章主要介紹了JavaScript實(shí)現(xiàn)京東購物放大鏡和選項卡效果的方法,結(jié)合實(shí)例形式分析了javascript基于事件響應(yīng)、數(shù)值計算與頁面元素動態(tài)修改實(shí)現(xiàn)圖片放大功能以及tab選項卡切換效果相關(guān)操作技巧,需要的朋友可以參考下
    2018-07-07

最新評論