摘要:簡介移動屏幕適配是一個比較令人頭疼的問題,這是我寫的一個通過動態(tài)設(shè)置的移動屏幕適配的工具函數(shù),包括定寬和兩種適配方法,目前在我自己的項目中用起來還不錯,后續(xù)也會優(yōu)化調(diào)整,地址這里。
2015-10-16更新。
簡介移動屏幕適配是一個比較令人頭疼的問題,這是我寫的一個通過動態(tài)設(shè)置viewport的移動屏幕適配的工具函數(shù),包括定寬和rem兩種適配方法,目前在我自己的項目中用起來還不錯,后續(xù)也會優(yōu)化調(diào)整,github地址這里。
說明頁面事先添加meta標(biāo)簽 ,然后調(diào)用方法如fixViewport("fixed", 640)即可。
參數(shù)type
適配類型(可選值為"fixed"或"rem")
width
設(shè)計稿寬度(整數(shù))
可以選擇以下兩種方式進(jìn)行屏幕適配:
定寬:
原理:設(shè)定viewport的寬度為固定值(即傳遞的width值),并根據(jù)屏幕寬度和width值計算viewport縮放比例。
實際開發(fā)在css中任何長度尺寸均使用px單位,大小設(shè)置為設(shè)計稿中原始尺寸值;
字體單位使用em, body下直接子元素字體大小設(shè)置為設(shè)計稿中尺寸值 / 100;
非直接子元素若其父元素未設(shè)置字體大小則與直接子元素相同,否則根據(jù)父元素字體大小計算其相對值。
rem:
原理:根據(jù)設(shè)備dpr和屏幕寬度來計算viewport寬度,并根據(jù)設(shè)備dpr計算viewport縮放比例,然后在html標(biāo)簽中設(shè)置font-size的屬性值。
實際開發(fā)在css中任何長度尺寸均使用rem單位,大小設(shè)置為設(shè)計稿中尺寸值 / 100;
字體單位使用em, body下直接子元素字體大小設(shè)置為設(shè)計稿中尺寸值 / 100;
非直接子元素若其父元素未設(shè)置字體大小則與直接子元素相同,否則根據(jù)父元素字體大小計算其相對值。
若需要1px物理像素的邊框效果,則border的寬度不需要使用rem,設(shè)定為1px即可。
/** * Created by GG on 15/7/29. * * 頁面事先添加meta標(biāo)簽 * 參數(shù):type(適配類型, 可選值為"fixed"或"rem");width(設(shè)計稿寬度,整數(shù)) * 可以選擇以下兩種情況適配: * 1. 定寬:原理是設(shè)定viewport的寬度為固定值(即傳遞的width值),并根據(jù)屏幕寬度和width值計算viewport縮放比例。 * 實際開發(fā)在css中任何長度尺寸均使用px單位,大小設(shè)置為設(shè)計稿中原始尺寸值; * 字體單位使用em, body下直接子元素字體大小設(shè)置為設(shè)計稿中尺寸值 / 100; * 非直接子元素若其父元素未設(shè)置字體大小則與直接子元素相同,否則根據(jù)父元素字體大小計算其相對值。 * 2. REM:原理是根據(jù)設(shè)備dpr和屏幕寬度來計算viewport寬度,并根據(jù)設(shè)備dpr計算viewport縮放比例,然后在html標(biāo)簽中設(shè)置font-size的屬性值。 * 實際開發(fā)在css中任何長度尺寸均使用rem單位,大小設(shè)置為設(shè)計稿中尺寸值 / 100; * 字體單位使用em, body下直接子元素字體大小設(shè)置為設(shè)計稿中尺寸值 / 100; * 非直接子元素若其父元素未設(shè)置字體大小則與直接子元素相同,否則根據(jù)父元素字體大小計算其相對值。 * 若需要1px物理像素的邊框效果,則border的寬度不需要使用rem,設(shè)定為1px即可。 */ (function () { function fixViewport(type, designWidth) { var metaEl = document.querySelector("meta[name="viewport"]"); //由于初始設(shè)置了viewport的width=device-width,所以此處docEl.clientWidth即是屏幕的設(shè)備寬度 var clientWidth = document.documentElement.clientWidth; var width, scale; switch (type) { case "fixed": width = designWidth; scale = clientWidth / designWidth; break; case "rem": var dpr = window.devicePixelRatio || 1; width = clientWidth * dpr; scale = 1 / dpr; document.documentElement.style.fontSize = 100 * (clientWidth * dpr / designWidth) + "px"; break; } metaEl.setAttribute("content", "width=" + width + ",initial-scale=" + scale + ",maximum-scale=" + scale + ",minimum-scale=" + scale); //設(shè)置body的基準(zhǔn)字體大小 document.body.style.fontSize = 50 / scale + "px"; } fixViewport("rem", 640); }());
文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請注明本文地址:http://m.specialneedsforspecialkids.com/yun/85827.html
摘要:屏幕適配是一個很容易被忽略的問題,但對于精益求精的產(chǎn)品而言,是必不可少的。對于開發(fā)的求職者而言,也是一個必需要理解清楚的經(jīng)典問題文啃先生壹移動端適配的是什么我們討論的是網(wǎng)頁適配多種尺寸屏幕,讓網(wǎng)頁效果看起來和設(shè)計師的設(shè)計稿一樣。 屏幕適配是一個很容易被忽略的問題,但對于精益求精的產(chǎn)品而言,是必不可少的。對于Web開發(fā)的求職者而言,也是一個必需要理解清楚的經(jīng)典問題 文 | 啃先生 Mar...
摘要:并且除了常用的端,還要考慮微信端,或者是端。所以我們要有一套機(jī)制,在端上走的代碼,在端或者微信端上走端對應(yīng)的代碼。對于一個從零開始的移動端項目,我總結(jié)了以上這些移動開發(fā)難點,希望之后的人能少踩點坑,站在我的肩膀上提高項目開發(fā)的效率和質(zhì)量。 從零搭建移動H5開發(fā)項目實戰(zhàn) 前端H5的前世今身 在Pc的時代,前端技術(shù)無疑統(tǒng)治了大多數(shù)用戶的交互界面!而在移動為王的今天,NA開發(fā)在早期占領(lǐng)了大多...
摘要:并且除了常用的端,還要考慮微信端,或者是端。所以我們要有一套機(jī)制,在端上走的代碼,在端或者微信端上走端對應(yīng)的代碼。對于一個從零開始的移動端項目,我總結(jié)了以上這些移動開發(fā)難點,希望之后的人能少踩點坑,站在我的肩膀上提高項目開發(fā)的效率和質(zhì)量。 從零搭建移動H5開發(fā)項目實戰(zhàn) 前端H5的前世今身 在Pc的時代,前端技術(shù)無疑統(tǒng)治了大多數(shù)用戶的交互界面!而在移動為王的今天,NA開發(fā)在早期占領(lǐng)了大多...
摘要:前言最近整理了一下以前學(xué)習(xí)前端的筆記,發(fā)現(xiàn)自己對移動端屏幕適配這一塊并沒有真正理解,只是會用。接下來,把自己的一些對移動端屏幕適配的思考記錄下來。量得的高度為,因為在設(shè)計稿這樣尺寸的屏幕中,,所以該的的值為,即。 前言 最近整理了一下以前學(xué)習(xí)前端的筆記,發(fā)現(xiàn)自己對移動 web 端屏幕適配(rem)這一塊并沒有真正理解,只是會用。接下來,把自己的一些對移動 web 端屏幕適配(rem)的...
摘要:前言最近整理了一下以前學(xué)習(xí)前端的筆記,發(fā)現(xiàn)自己對移動端屏幕適配這一塊并沒有真正理解,只是會用。接下來,把自己的一些對移動端屏幕適配的思考記錄下來。量得的高度為,因為在設(shè)計稿這樣尺寸的屏幕中,,所以該的的值為,即。 前言 最近整理了一下以前學(xué)習(xí)前端的筆記,發(fā)現(xiàn)自己對移動 web 端屏幕適配(rem)這一塊并沒有真正理解,只是會用。接下來,把自己的一些對移動 web 端屏幕適配(rem)的...
閱讀 794·2021-08-23 09:46
閱讀 942·2019-08-30 15:44
閱讀 2599·2019-08-30 13:53
閱讀 3048·2019-08-29 12:48
閱讀 3864·2019-08-26 13:46
閱讀 1793·2019-08-26 13:36
閱讀 3518·2019-08-26 11:46
閱讀 1418·2019-08-26 10:48