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

flexible.js實(shí)現(xiàn)移動(dòng)端rem適配方案

 更新時(shí)間:2020年04月07日 11:23:07   作者:錢不多啊  
這篇文章主要介紹了flexible.js實(shí)現(xiàn)移動(dòng)端rem適配方案,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧

需要了解的基礎(chǔ)知識(shí):

物理像素:物理像素又被稱為設(shè)備像素,他是顯示設(shè)備中一個(gè)最微小的物理部件。每個(gè)像素可以根據(jù)操作系統(tǒng)設(shè)置自己的顏色和亮度。正是這些設(shè)備像素的微小距離欺騙了我們?nèi)庋劭吹降膱D像效果。

設(shè)備獨(dú)立像素:也稱為密度無關(guān)像素,可以認(rèn)為是計(jì)算機(jī)坐標(biāo)系統(tǒng)中的一個(gè)點(diǎn),這個(gè)點(diǎn)代表一個(gè)可以由程序使用的虛擬像素(比如說CSS像素),然后由相關(guān)系統(tǒng)轉(zhuǎn)換為物理像素。

設(shè)備像素比:簡(jiǎn)稱為dpr,其定義了物理像素和設(shè)備獨(dú)立像素的對(duì)應(yīng)關(guān)系。它的值可以按此公式計(jì)算得到:設(shè)備像素比 = 物理像素 / 設(shè)備獨(dú)立像素 (安卓一般為:1;iPhone為2或者3)

visual viewport:可見視口,即屏幕寬度;

layout viewport:布局視口,即DOM寬度;

idea viewport:理想適口,使布局視口就是可見視口;

設(shè)備寬度(visual viewport)與DOM寬度(layout viewport),scale的關(guān)系是:(visual viewport)= (layout viewport)* scale

獲取屏幕寬度的尺寸:window. innerWidth/Height

獲取DOM寬度的尺寸:document. documentElement. clientWidth/Height

viewport的meta標(biāo)簽

<meta name="viewport" content="width=device-width, initial-scale=1, maximum-scale=1">
  • initial-scale:‘設(shè)置頁面的初始縮放值,為一個(gè)數(shù)字,可以帶小數(shù)';
  • maximum-scale:‘允許用戶的最大縮放值,為一個(gè)數(shù)字,可以帶小數(shù)';
  • user-scalable:‘是否允許用戶進(jìn)行縮放,值為"no"或"yes", no 代表不允許,yes代表允許';

**flexible.js:**手機(jī)淘寶團(tuán)隊(duì)的熱門適配方案

源碼解析:

// 首先是一個(gè)立即執(zhí)行函數(shù),執(zhí)行時(shí)傳入的參數(shù)是window和document
(function flexible (window, document) {
 var docEl = document.documentElement // 返回文檔的root元素
 var dpr = window.devicePixelRatio || 1 
 // 獲取設(shè)備的dpr,即當(dāng)前設(shè)置下物理像素與虛擬像素的比值

 // 調(diào)整body標(biāo)簽的fontSize,fontSize = (12 * dpr) + 'px'
 // 設(shè)置默認(rèn)字體大小,默認(rèn)的字體大小繼承自body
 function setBodyFontSize () {
 if (document.body) {
  document.body.style.fontSize = (12 * dpr) + 'px'
 } else {
  document.addEventListener('DOMContentLoaded', setBodyFontSize)
 }
 }
 setBodyFontSize();

 // set 1rem = viewWidth / 10
 // 設(shè)置root元素的fontSize = 其clientWidth / 10 + ‘px'
 function setRemUnit () {
 var rem = docEl.clientWidth / 10
 docEl.style.fontSize = rem + 'px'
 }

 setRemUnit()


 // 當(dāng)我們頁面尺寸大小發(fā)生變化的時(shí)候,要重新設(shè)置下rem 的大小
 window.addEventListener('resize', setRemUnit)
  // pageshow 是我們重新加載頁面觸發(fā)的事件
 window.addEventListener('pageshow', function(e) {
  // e.persisted 返回的是true 就是說如果這個(gè)頁面是從緩存取過來的頁面,也需要從新計(jì)算一下rem 的大小
  if (e.persisted) {
   setRemUnit()
  }
 })

 // 檢測(cè)0.5px的支持,支持則root元素的class中有hairlines
 if (dpr >= 2) {
 var fakeBody = document.createElement('body')
 var testElement = document.createElement('div')
 testElement.style.border = '.5px solid transparent'
 fakeBody.appendChild(testElement)
 docEl.appendChild(fakeBody)
 if (testElement.offsetHeight === 1) {
  docEl.classList.add('hairlines')
 }
 docEl.removeChild(fakeBody)
 }
}(window, document))

不想看原理可以直接看這里按步驟使用即可

1. 在index.html文件使用CDN引入flexible.js文件。

// 引用地址
<script src="http://g.tbcdn.cn/mtb/lib-flexible/0.3.2/??flexible_css.js,flexible.js">
</script>

下面的這個(gè)meta標(biāo)簽 頁面不要設(shè)定, Flexible會(huì)自動(dòng)設(shè)定每個(gè)屏幕寬度的根font-size、動(dòng)態(tài)viewport、針對(duì)Retina屏做的dpr。

// 這個(gè)標(biāo)簽不要設(shè)定!??!
<!-- <meta name="viewport" content="width=device-width,initial-scale=1.0,minimum-scale=1.0,maximum-scale=1.0"> -->

2. 把視覺稿中的px轉(zhuǎn)換成rem

一般UI給我們的稿子大小是750的。就以這個(gè)為例子:在flexible.js中,把750px分為10份,1rem 為 75px。所以font-size的基準(zhǔn)值為75px;
css換算成rem公式為: px值 / 75 = rem, 例如:100px=100/75=1.33rem
但是這樣一來計(jì)算起來就非常的復(fù)雜。那么我們?cè)谌粘i_發(fā)中怎么快速計(jì)算呢,這里我說下我常用的編譯器VScode 它里面有個(gè)插件叫cssrem,用它就可以在我們輸入px值后自動(dòng)轉(zhuǎn)換rem。

安裝方法如下:

①:安裝插件

②:修改配置參數(shù)

當(dāng)設(shè)計(jì)圖為750時(shí)在下圖中這里填寫75
root font-size (unit: px), default: 16
這代表根字體大小,默認(rèn)是16px,即1rem = 16px,我們這里把他改為75。
cssrem.fixedDigits px轉(zhuǎn)rem小數(shù)點(diǎn)最大長(zhǎng)度,默認(rèn):6。

③:修改完參數(shù)后我們只要輸入px值插件就會(huì)自動(dòng)算出rem值,效果如下圖:


到此這篇關(guān)于flexible.js實(shí)現(xiàn)移動(dòng)端rem適配方案的文章就介紹到這了,更多相關(guān)flexible.js 移動(dòng)端rem適配內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • js實(shí)現(xiàn)按座位號(hào)抽獎(jiǎng)

    js實(shí)現(xiàn)按座位號(hào)抽獎(jiǎng)

    本文主要介紹了js實(shí)現(xiàn)按座位號(hào)抽獎(jiǎng)的示例代碼。具有很好的參考價(jià)值。下面跟著小編一起來看下吧
    2017-04-04
  • JS 獲取滾動(dòng)條高度示例代碼

    JS 獲取滾動(dòng)條高度示例代碼

    滾動(dòng)條高度如何獲取,方法有很多,在本文將為大家詳細(xì)介紹下如何使用js做到,下面有個(gè)不錯(cuò)的示例,感興趣的朋友不要錯(cuò)過
    2013-10-10
  • layui下拉框獲取下拉值(select)的例子

    layui下拉框獲取下拉值(select)的例子

    今天小編就為大家分享一篇layui下拉框獲取下拉值(select)的例子,具有好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧
    2019-09-09
  • JavaScript頁面倒計(jì)時(shí)功能完整示例

    JavaScript頁面倒計(jì)時(shí)功能完整示例

    這篇文章主要介紹了JavaScript頁面倒計(jì)時(shí)功能,結(jié)合完整實(shí)例形式分析了javascript計(jì)時(shí)器、時(shí)間運(yùn)算相關(guān)操作技巧,需要的朋友可以參考下
    2019-05-05
  • three.js開發(fā)3d地圖的實(shí)現(xiàn)示例

    three.js開發(fā)3d地圖的實(shí)現(xiàn)示例

    本文主要介紹了three.js開發(fā)3d地圖的實(shí)現(xiàn)示例,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2023-07-07
  • JS實(shí)現(xiàn)自定義彈窗功能

    JS實(shí)現(xiàn)自定義彈窗功能

    瀏覽器自帶的原生彈窗很不美觀,而且功能比較單一,絕大部分時(shí)候我們都會(huì)按照設(shè)計(jì)圖自定義彈窗或者直接使用注入layer的彈窗等等。下面小編給大家?guī)砹薐S實(shí)現(xiàn)自定義彈窗,感興趣的朋友一起看看吧
    2018-08-08
  • Ext JS動(dòng)態(tài)加載JavaScript創(chuàng)建窗體的方法

    Ext JS動(dòng)態(tài)加載JavaScript創(chuàng)建窗體的方法

    這篇文章主要介紹了Ext JS動(dòng)態(tài)加載JavaScript創(chuàng)建窗體的方法 ,需要的朋友可以參考下
    2016-06-06
  • 簡(jiǎn)單談?wù)刯son跨域

    簡(jiǎn)單談?wù)刯son跨域

    本文主要給大家講解了javascript中的json跨域問題,以及跨域安全性的解決辦法,總結(jié)了2點(diǎn),分享給大家,希望大家能夠喜歡。
    2016-03-03
  • js GridView 實(shí)現(xiàn)自動(dòng)計(jì)算操作代碼

    js GridView 實(shí)現(xiàn)自動(dòng)計(jì)算操作代碼

    js操作GridView,實(shí)現(xiàn)自動(dòng)計(jì)算的實(shí)現(xiàn)代碼,下面的代碼運(yùn)行即可
    2009-03-03
  • 微信小程序結(jié)合mock.js實(shí)現(xiàn)后臺(tái)模擬及調(diào)試

    微信小程序結(jié)合mock.js實(shí)現(xiàn)后臺(tái)模擬及調(diào)試

    這篇文章主要介紹了微信小程序結(jié)合mock.js實(shí)現(xiàn)后臺(tái)模擬及調(diào)試,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-03-03

最新評(píng)論