做移动端或者响应式的页面必然需要字体的变化的。这次我就自己的经验来说说他们之间的关系,以及怎么用。

px (绝对单位)是我们常用的就不说了。

em(相对单位,相对父级)

em 指字体高,任意浏览器的默认字体高都是16px。所以未经调整的浏览器都符合: 1em=16px。那么12px=0.75em, 10px=0.625em。为了简化font -size的换算,需要在css中的body选择器中声明Font-size=62.5%,这就使em值变为16px*62.5%=10px, 这样12px=1.2em, 10px=1em, 也就是说只需要将你的原来的px数值除以10,然后换上em作为单位就行了。

CSS代码
html { font-size: 62.5%; }

这个换算在IE浏览器下不成立,1.2em会比12px稍大一些,解决办法是把html标签样式中的62.5%改成63%,即:
CSS代码
html { font-size: 63%; }

注:(有一点不懂的是)

你可能会在content这个div里把字体大小设为1.2em, 也就是12px。然后你又把选择器p的字体大小也设为1.2em,但如果p属于content的子级的话,p的字体大小就不是12px,而是1.2em= 1.2 * 12px=14.4px。这是因为content的字体大小被设为1.2em,这个em值继承其父级元素body的大小,也就是16px * 62.5% * 1.2=12px, 而p作为其子级,em则继承content的字体高,也就是12px。所以p的1.2em就不再是12px,而是14.4px。

所以这个用的时候会有点问题

rem(相对单位 ,css3,相对根),在ie8及ie8以下的版本不支持外其他浏览器都支持,如果你要考虑ie8及一下,最好把px也写上。

我们设置html的字体大小的值为html{font-size: 87.5%;}(也就是14px)。然后其他的字体就是将你要的值除以14得到的值

你根元素的字体大小选62.5%,那px和rem之间的换算就是px直接除以10就得到rem了。

这里我就不负责任说一句,这里是看到别人写的,我自己还没哟用过,不知道什么样。

javascript方式,通过上面的公式,计算出基准值rem,然后写入样式,大概如下(代码参考自kimi的m-base模块)

var dpr, rem, scale;
var docEl = document.documentElement;
var fontEl = document.createElement('style');
var metaEl = document.querySelector('meta[name="viewport"]');
scale = 1 / dpr;
dpr = win.devicePixelRatio || 1;
rem = docEl.clientWidth * dpr / 10;
// 设置viewport,进行缩放,达到高清效果
metaEl.setAttribute('content''width=' + dpr * docEl.clientWidth + ',
                     initial-scale=' + scale + ',maximum-scale=' + scale + ',
                     minimum-scale=' + scale + ',user-scalable=no');
// 设置data-dpr属性,留作的css hack之用
docEl.setAttribute('data-dpr', dpr);
// 动态写入样式
docEl.firstElementChild.appendChild(fontEl);
fontEl.innerHTML = 'html{font-size:' + rem + 'px!important;}';
// 给js调用的,某一dpr下rem和px之间的转换函数
window.rem2px = function(v) {
    v = parseFloat(v);
    return v * rem;
};
window.px2rem: function(v) {
    v = parseFloat(v);
    return v / rem;
};
window.dpr = dpr;
window.rem = rem;

这种方式,可以精确地算出不同屏幕所应有的rem基准值,缺点就是要加载这么一段js代码,但个人觉得是这是目前最好的方案了。

因为这个方案同时解决了三个问题:

1)border: 1px问题

2)图片高清问题

3)屏幕适配布局问题

推荐网页:http://www.cocoachina.com/webapp/20150715/12585.html

转载于:https://www.cnblogs.com/zxhh/p/6872318.html

px ,em ,rem相关推荐

  1. px,em,rem,vh,vw,vmin,vmax的区别

    css手册中关于font-size是这么介绍的: font-size 值可以是绝对或相对值. 绝对值: 将文本设置为指定的大小 不允许用户在所有浏览器中改变文本大小(不利于可用性) 绝对大小在确定了输 ...

  2. html移动端怎么做城市选择,移动端页面单位的选择(px, em, rem, vw)

    px, em, rem的区别: px:绝对字体大小 em:基于一个基数来计算出相对字体大小.(移动端用的少) rem:基于根节点(html)的字体大小来计算. vw:可视区宽度单位.1vw等于可视区宽 ...

  3. css中的单位换算_css大小单位px em rem的转换和详解

    css大小单位px em rem的转换和详解 PX特点 1. IE无法调整那些使用px作为单位的字体大小: 2. 国外的大部分网站能够调整的原因在于其使用了em或rem作为字体单位: 3. Firef ...

  4. CSS单位--px,em,rem,rpx区别

    国内的设计师大都喜欢用px,而国外的网站大都喜欢用em和rem,那么三者有什么区别,又各自有什么优劣呢? Px PX特点 1. IE无法调整那些使用px作为单位的字体大小: 2. 国外的大部分网站能够 ...

  5. 认识css长度单位 px % em rem vh vw

    目录 长度单位 px % em rem vh.vw 总结 长度单位 在日常的项目开发,在使用css样式进行时布局的时候,我们常常用到px.%.em这三个单位.CSS3开始,浏览器新增加了rem.vh. ...

  6. 网页布局中的 px,em,rem,pt

    网页布局中的 px,em,rem,pt 设备像素:也叫物理像素,显示设备上最微小的物理部件. 比如 iphone 5:640 x 1136px. 不同的机型有不同的设备像素,固定死的. 这里需要讲一下 ...

  7. html 字号和像素的关系,一文搞懂CSS中的字体单位大小(px,em,rem...)

    在学习的过程中,发现CSS有很多可以形容单位的尺寸.比方px,em,rem,vw等等.平常也没有深究,一来是没时间,二来是在我学习清单中优先级过低.一直想彻底弄明白,一直耽搁到现在.现在花上一点时间来 ...

  8. 移动端页面单位的选择(px em rem)

    移动端页面单位的选择(px em rem) 绝对单位:  px 相对单位:  rem  em em具有继承性  继承自直接父类  所以说在移动端很少用 浏览器默认的字体大小 16px  那么 1em= ...

  9. CSS中的常见单位(px,%,em,rem,vw,vh,vmax,vmin,calc)

    像素(px)&百分比(%) 像素(Pixel) 长度单位,相对于显示器屏幕分辨率而言,通常在不定义显示缩放比例的情况下,1px对应显示器屏幕上的一个像素点. 早年的pc端展示的页面基本都用这个 ...

最新文章

  1. ORACLE SQL SET运算符
  2. 【NOIP2013模拟】小喵喵的新家
  3. 领域应用 | 知识计算,华为云赋能企业知识化转型
  4. python 按照当前日期创建文件
  5. 建好ftp服务器后怎么从客户端更改密码?
  6. Debian,从安装到喜欢
  7. c语言头文件下载微盘,c语言头文件下载 C语言头文件大全.doc
  8. 光耦驱动单向可控硅_超低功耗光电耦合驱动单向可控硅电路,光电耦合器
  9. websphere html 缓存,如何清除WebSphere类缓存
  10. 深入Java虚拟机(五)垃圾收集
  11. ubantu 安装 mosquitto时 connection refused 的解决办法
  12. URL deconding URL解码
  13. Java通过jacob生成动态word,还有一种方法通过word书签实现
  14. Python 百天读书笔记 | Python语言进阶 16-20day
  15. k8s 使用HPA 进行弹性扩容pod节点,
  16. UltraISO PE 绿色版9.1.2.2463
  17. 安卓APP跟iOSAPP之间的对比
  18. 7-3 Swan学院社团招新
  19. 【学习笔记】阿里云天池龙珠计划SQL训练营-Task06:综合练习题-10道经典题目
  20. org.apache.ibatis.type.TypeException: Could not resolve type alias 'xxxx'异常

热门文章

  1. 第二章 Burp Suite代理和浏览器设置
  2. 关于msbuild 编译.net 4.5新语法错误的解决方法
  3. Eigen(6)快操作
  4. 你应当如何学习C++(以及编程)(rev#1)
  5. Linux(CentOS)挂载U盘、移动硬盘以及文件拷贝、备份
  6. 汽车电子专业知识篇(一)-汽车行业质量人必知的41个体系术语
  7. 一文通读传感器到算法原理,机器人、视觉避障(附源码)
  8. java mvc中重复提交表单,spring mvc 防止重复提交表单的两种方法,推荐第二种
  9. 前端面试题之http/HTML/浏览器(一)
  10. 一种移动端自适应屏幕的方法