找了很多的文档,就这个问题,越看越糊涂,写的公式都是直接给出,但是并没有说公式是怎么推演出来的,搞得我好烦。rem =x/75, 实在搞不懂,就自己写了,
大家都明白,假设html的fontSize:16px;那么1rem = 16px;是不是可以理解为1个rem单位等于16px;
以750的设计稿为例:(手淘插件 flexible.js)
1--把设计稿平均分成10份,每份是750/10=75px;把每份假设为一个叫xm单位,那么就是1xm = 75px;这句是不是和上一句很像,可以假设为750px的页面,他的html的fontsize=75px;
2--现在想一下手机是375px的页面,也把他按照步骤1平均分成10份,每份375/10 = 37.5px, 设置为html的fontsize ,结果:1rem = 37.5px; 那么其他的手机的html的fontsize用js表示
fontSize = document.documentElement.clientWidth/10 + "px";
3--暂时忘记1,2步骤,iphone6是2倍像素的手机,与设计稿对比,750的宽,在iphone6是375px,或者,量取设计稿中一个元素,width = 100px, 那么在手机端css的值应为50px,看下列表格,已经知道的数据就是前两列的值。那么后两列的值是怎么算的呢
750UI图假设的fontsize的值(步骤1)
手机 html fontsize的值(步骤2)
UI量取的宽度(