探究为何rem在chrome浏览器上计算出错

最近在一个项目中,测试同学提了一个bug,说手机上有个页面的某些字体显示偏大。就像这样

我用chrome浏览器在pc上测试了一下,发现pc上也有这个问题,但是用其它浏览器打开这个页面就没有发现这个问题。

于是,上网百度了一下,发现原来是chrome浏览器的问题。

通过各种百度Google然后我总结了一下这个问题产生的原因:

chrome浏览器目前支持的最小的字体大小为12px,而我在html根元素上设置font-size:62.5%,计算之后就是10px,1rem=10px。

由于我页面字体大小都是按照10px的基数去算的,所以当chrome浏览器计算字体大小时就出现了出错。

解决方案:

又经过一番百度Google之后,总结了一下这种问题的解决方法。

网上提供的两种最多的解决方案就是

1、js方法

<script type="text/javascript">
document.body.style.fontSize = ‘1.6rem‘;
</script>

具体的字号根据你的项目来决定

2、css方法

<style>
body {
font-size: 1.6rem;
}
</style>

将这个样式插入到head标签里面

这两种方式我都试用了,但是并没有效果,我也不清楚是怎么回事,如果有大神知道,还望不吝赐教。

所以,目前我认为最根本的解决方法就是,将html根元素的font-size大小设置为大于等于12px。

一些疑惑:

1、当1rem小于12px时,chrome是怎么计算的。

如上图所示,我的html根元素的font-size设置为62.5%(10px),图中字体计算的时候并不是25px,而是28.5941px,这个数是怎么来的,如果按照最小12px来算应该是30px才对啊。

2、为啥有的字体计算正确,有的出错。

如上图所示,同样设置为2.5rem的字体,有的能正确计算出是25px,有的却不行,这是怎么回事呢?

希望了解其中缘由的人能不吝赐教。

时间: 2024-07-30 19:28:37

探究为何rem在chrome浏览器上计算出错的相关文章

如何在老版本的Chrome 浏览器上使用selenium

由于Chrome Driver 只兼容Chrome  浏览器12.0.712.0 和之后的新版本,会因此如果要在老版本的Chrome  浏览器上使用Selenium, 则只能使用 SeleniumRC来完成任务,示例代码: URL seleniumRC = new URL("http://localhost:4444"); URL testWebLink = new URL("http://www.google.com"); CommandExecutor exec

解决Shockwave flash在chrome浏览器上崩溃的问题

越来越多的人開始使用chrome浏览器,非常多用户都遇到过flash崩溃的问题,有时候重新启动chrome能够解决,有时候会导致无法用chrome打开不论什么站点上的不论什么flash.这个问题非常少在Firefox或者IE上发生,原因是除了chrome以外的浏览器都直接使用第三方的插件,比方adobe的,而仅仅有chrome除了使用第三方插件之外,自身还内置了一个flash播放器.chrome的非常多这种功能设计使得它在速度,效率,外观,使用方便性上面胜出它的竞争对手,但也带来一些小问题,比方

[转载]为什么有些MP4文件在Chrome浏览器上播放不了?

http://blog.sina.com.cn/s/blog_6bb7ebcc0101c2ja.html Chrome浏览器支持HTML5,它支持原生播放部分的MP4格式(不用通过Flash等插件). 为什么是部分MP4呢?MP4有非常复杂的含义(见http://en.wikipedia.org/wiki/Mp4),普通人对MP4的理解是后缀为.mp4的文件.但MP4本身不是一种简单的视频格式,它是一个包装了视频和音频格式的壳.至于里面的视频和音频使用什么编码格式是可变的.MP4的视频格式可以使

让你的「微信小程序」运行在Chrome浏览器上,让我们使用WebStorm

「微信小程序」的开发框架体验起来,还不错--自带了UI框架.但是问题是他的IDE,表现起来相当的糟糕--其实主要是因为,我当时买WebStorm License买了好多年.所以,我觉得他的IDE真不如我这个付费好用. 而且,作为一个拥护自由和开源的 「GitHub 中国区首席Markdown程序员」.微信在「微信小程序」引导着Web开向封闭,我们再也不能愉快地分享我们的代码了. 如果我们放任下去,未来的Web世界令人堪忧. 好了,废话说完了: 文章太长不想看,可以直接看Demo哈哈: GitHu

SocketLog-微信调试、API调试和AJAX的调试的工具,能将日志通过WebSocket输出到Chrome浏览器的console中

说明 SocketLog适合Ajax调试和API调试, 举一个常见的场景,用SocketLog来做微信调试, 我们在做微信API开发的时候,如果API有bug,微信只提示"改公众账号暂时无法提供服务,请稍候再试" ,我们根本不知道API出来什么问题. 有了SocketLog就不一样了, 我们可以知道微信给API传递了哪些参数, 程序有错误我们也能看见错误信息(下方有张图片,可能加载慢,请耐心等待一下) 正在运行的API有bug,不能var_dump进行调试,因为会影响client的调用

XP系统下Chrome浏览器打开某些网站闪退的解决办法

这个星期用Chrome浏览网站的过程中,突然出现没有什么提示的闪退现象.一开始没怎么注意,以为只是偶然现象,但当重启Chrome后点恢复按钮再次闪退,这就可以肯定是因为打开某些网站造成.于是再次重启Chrome浏览器并按下恢复按钮,在可能导致Chrome闪退那个网站打开之前关闭那个分页,这样Chrome就不闪退了.这个办法只能治标不能治本,下次再打开这个网站同样会出现闪退的现象. 为了彻底解决这个问题,于是就用搜索引擎找找看有没有解决办法.首先用"Chrome打开某些网站闪退"作为关键

关于 百度 Ueditor (在chrome浏览器) 上传图片时 打开文件夹的延迟问题

在使用 ueditor 开发时, 作为一个web文本编辑器使用时. 当点击上传图片时, 文件夹要延迟好久才能打开. 解决: 针对多图片上传, 将/ueditor/dialogs/image/image.js 文件下的以下代码 accept: { title: 'Images', extensions: acceptExtensions, mimeTypes: 'image/*' }, 改为 accept: { title: 'Images', extensions: acceptExtensio

Selenium Chrome浏览器的启动以及proxy设置

虽然WebDriver对Firefox的支持最好,之前写的脚本也都在Firefox浏览器运行,但最近项目做了整合,发现新整合的功能不太支持Firefox,而近期也没有计划做浏览器兼容性方面的改进,所以我的自动化脚本要重新修改,运行在都有良好支持的Chrome浏览器上.说了这么多背景,我们就进入正题吧. 1. 首先需要下载chromeDriver. http://chromedriver.storage.googleapis.com/index.html 2. 将下载好的文件解压,将chromed

Python+Selenium2自动化测试之IE、chrome浏览器启动

构建Python+Selenium2自动化测试环境完成之后,就需要测试支持python的selenium的版本是否都支持在不同浏览器上运行,当前我们分别在三个最通用的浏览器上通过脚本来测试. 1.在IE浏览器上运行测试脚本,首先需要下载IEDriverServer.exe,放在IE浏览器的安装目录且同级目录下,脚本如下: import os from selenium import webdriver from selenium.webdriver.common.keys import Keys