博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
理解rem实现响应式布局原理及js动态计算rem
阅读量:5305 次
发布时间:2019-06-14

本文共 962 字,大约阅读时间需要 3 分钟。

前言

  移动端布局中,童鞋们会使用到rem作为css单位进行不同手机屏幕大小上的适配。那么来讲讲rem在其中起的作用和如何动态设置rem的值。

1、什么是rem

  rem是相对于根元素(html标签)的字体大小的单位。

2、rem实现适配的原理

  核心思想:百分比布局可实现响应式布局,而rem相当于百分比布局。

  实现手段:动态获取当前视口宽度width,除以一个固定的数n,得到rem的值。表达式为rem = width / n。

  通过此方法,rem大小始终为width的n等分。

3、如何动态计算rem

  核心代码块:

// 动态为根元素设置字体大小         function init () {
      // 获取屏幕宽度 var width = document.documentElement.clientWidth       // 设置根元素字体大小。此时为宽的10等分 document.documentElement.style.fontSize = width / 10 + 'px' }      //      首次加载应用,设置一次 init() // 监听手机旋转的事件的时机,重新设置 window.addEventListener('orientationchange', init) // 监听手机窗口变化,重新设置 window.addEventListener('resize', init)   理解:上面代码实现了,无论设备可视窗口如何变化,始终设置rem为width的1/10.即实现了百分比布局 4、tip:
  1、以上代码需在dom之前写入(可放在head里面第一个script标签)   2、移动端加上meta标签
5、使用体验:   我在项目中没有使用flexible.js等此类动态计算rem的插件。另外说明一点,此方法实现的功能也相对简单,只实现了最核心的动态修改rem的值。

 

                

转载于:https://www.cnblogs.com/damonFeng/p/7880926.html

你可能感兴趣的文章
arcgis api 4.x for js 结合 Echarts4 实现散点图效果(附源码下载)
查看>>
YTU 2625: B 构造函数和析构函数
查看>>
apache自带压力测试工具ab的使用及解析
查看>>
C#使用Xamarin开发可移植移动应用(2.Xamarin.Forms布局,本篇很长,注意)附源码
查看>>
jenkins搭建
查看>>
C#中使用Split分隔字符串的技巧
查看>>
eclipse的调试方法的简单介绍
查看>>
加固linux
查看>>
IPSP问题
查看>>
HNU 10362 A+B for Input-Output Practice (II)
查看>>
10.17动手动脑
查看>>
WPF中Image显示本地图片
查看>>
Windows Phone 7你不知道的8件事
查看>>
脚本删除文件下的文件
查看>>
实用拜占庭容错算法PBFT
查看>>
java的二叉树树一层层输出,Java构造二叉树、树形结构先序遍历、中序遍历、后序遍历...
查看>>
php仿阿里巴巴,php实现的仿阿里巴巴实现同类产品翻页
查看>>
Node 中异常收集与监控
查看>>
七丶Python字典
查看>>
Excel-基本操作
查看>>