移動(dòng)端rem適配js 為什么很多web項(xiàng)目還是使用px,而不是rem?
為什么很多web項(xiàng)目還是使用px,而不是rem?在移動(dòng)終端剛剛流行的初期,為了使手機(jī)頁(yè)面適應(yīng)不同大小的手機(jī)屏幕,淘寶的一位前端老板編寫了一個(gè)經(jīng)過(guò)改編的JS,叫做flexible,可以在GitHub找到
為什么很多web項(xiàng)目還是使用px,而不是rem?
在移動(dòng)終端剛剛流行的初期,為了使手機(jī)頁(yè)面適應(yīng)不同大小的手機(jī)屏幕,淘寶的一位前端老板編寫了一個(gè)經(jīng)過(guò)改編的JS,叫做flexible,可以在GitHub找到。原理很簡(jiǎn)單。似乎根據(jù)手機(jī)的分辨率和DPI(我不記得了),動(dòng)態(tài)設(shè)置根元素HTML的fontsize,然后頁(yè)面元素的大小就是rem,因?yàn)?rem=fontsizeofhtml。
后來(lái),出現(xiàn)了大眾和VH。漸漸地,許多項(xiàng)目使用大眾汽車進(jìn)行改編。100vw=100%寬度。因?yàn)榧嫒菪圆皇呛芎?,所以一直沒(méi)有上線。
nodejs出現(xiàn)后,前端工程開始了。有pxtorem和pxtoview port等插件。在開發(fā)過(guò)程中,我們可以根據(jù)UI標(biāo)記的PX case直接編寫它們。在打包時(shí),插件將幫助我們將PX計(jì)算轉(zhuǎn)換為REM或VW。
我現(xiàn)在用大眾。不考慮兼容性。我甚至不看那些需要與ie兼容的公司。<html style=“字體大?。?00px”>
2。<body style=“字體-尺寸:14px“>
3。使用js計(jì)算當(dāng)前頁(yè)面寬度(PX),然后除以3.2。假設(shè)設(shè)計(jì)吃水寬度為320px。然后將設(shè)計(jì)草圖上元素的寬度除以100,設(shè)置為CSS的REM單位。例如,設(shè)計(jì)草圖中按鈕的寬度為100px。然后用CSS寫寬度:1rem IfCSS中的所有單位都是rem。無(wú)論當(dāng)前瀏覽器的大小,網(wǎng)頁(yè)看起來(lái)都像一個(gè)放大縮小的基于320的設(shè)計(jì)手稿。