适配手机页面布局的动态rem方案

1. 基础概念

em:一个汉字宽
rem:根元素(<html>元素)的font-size
chrome浏览器的font-size默认值16px (注意:最小是12px,再小无效)
rem和em的区别?没什么关系
1em = 本身元素的font-size(可以这样理解,不过不准确)
1rem = 根元素的font-size的大小

2. 动态 rem 方案

由于手机屏幕众多导致的尺寸不同的问题,我们需要一种自适应方案。
自适应方案可以用百分比布局 缺点:高度不能和宽度配合。
rem方案是以屏幕宽为基准的方案,通过js动态获取屏幕的宽度,从而和rem产生联系。

var pageWidth = window.innnerWidth
document.write('<style>html{font-size:' + pageWidth/10 + 'px;'}</style>')

这样 1rem = html的font-size = 1/10 pageWidth


1.png

注意:使用rem方案,经常犯的错误就是,js动态更改根元素html元素的font-size时,如果换算比例过小(/100),换导致html的font-size小于12px,chrom默认不能小于,这就出错了,不容易被察觉。
利用rem和其他单位混用可以达到很好的效果。

3. 在 SCSS 里使用 PX2REM,自动进行rem值换算

利用scss,我们就不用自己手算了,设计稿是多少就写多少,再将scss文件转成css文件即可。
使用步骤(windows可用,命令行工具是git bash)

  • npm config set registry https://registry.npm.taobao.org/
  • touch ~/.bashrc
  • echo 'export SASS_BINARY_SITE="https://npm.taobao.org/mirrors/node-sass"' >> ~/.bashrc
  • source ~/.bashrc
  • npm i -g node-sass
  • mkdir ~/Desktop/scss-demo
  • cd ~/Desktop/scss-demo
  • mkdir scss css
  • touch scss/style.scss
  • start scss/style.scss
  • node-sass -wr scss -o css
    编辑 scss 文件就会自动得到 css 文件
    在 scss 文件里添加
@function px( $px ){
  @return $px/$designWidth*10 + rem;
}   
$designWidth : 640; // 640 是设计稿的宽度,你要根据设计稿的宽度填写。
.child{
  width: px(320);
  height: px(160);
  margin: px(40) px(40);
  border: 1px solid red;
  float: left;
  font-size: 1.2em;
}
2.png

即可实现 px 自动变 rem,不需要手动换算。

©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容