- objective-c - iOS 5 : Can you override UIAppearance customisations in specific classes?
- iphone - 如何将 CGFontRef 转换为 UIFont?
- ios - 以编程方式关闭标记的信息窗口 google maps iOS
- ios - Xcode 5 - 尝试验证存档时出现 "No application records were found"
我一直在为这个问题绞尽脑汁,谷歌搜索并没有真正提供太多帮助,甚至没有关于这个问题的文档,但它极大地影响了我目前向移动友好型设计的转变。
无论我走到哪里,每个人都在吹捧使用基于 rem
的布局作为新的黄金标准,从表面上看,这种方法的优点似乎很理想(对基于引用像素的缩放和字体的完全可访问性支持- 尺寸缩放以支持多种 DPI 和多种屏幕尺寸/设置)。
然而,我遇到了一个相当大的障碍,我发现 Chrome(可能还有所有 webkit 浏览器,但我没有 mac atm 来测试)似乎没有像剩下的。
初始设置如下:
html { font-size: 62.5%; }
body { font-size: 1.6rem; }
我们应该能够使用以 rems 为单位的像素大小的 1/10 来设置我们所有的测量值:
.my-element { height: 15rem; } /* 150px */
我创建了一个简单示例来说明我的问题:https://jsfiddle.net/gLkpz88q/2/embedded/result/
当您使用 Chrome 并以这种方式向外扩展时,请注意布局如何停止缩放但内容会继续。
将此与 Firefox、IE11、Edge 进行比较,您根本看不到这种行为,它们都统一且持续地缩放。
这是(左上角:Chrome,右上角:IE11,左下角:Edge,右下角:FireFox)并排显示:
如您所见,如果 rem
单位的缩放比例与其他所有单位不同,这会对布局产生一些可怕的影响。
我不确定如何继续这个场景,因为 WebKit/Chrome 似乎决定以完全不同的方式处理缩放,这需要质疑所有 future 的缩放场景。
有很多文章提倡只使用像素,因为 CSS 引用像素 很好地处理了移动缩放:
然而,这些往往会忽略字体缩放问题,认为这是不太可能发生的情况。
我快速浏览了一些我能想到的大型和成功公司的大型移动友好/友好网站,似乎他们中的大多数只使用像素来满足他们所有的布局需求。 (Google、Facebook、Wordpress、Twitter、Bootstrap 3、[在某种程度上还有 Bootstrap 4]、MDN 和 WebPlatform )
Chrome 是新的违反标准的 IE 吗?还是我做错了什么?为了保持一致性,我很想在这一点上只使用像素。
最佳答案
我将首先解决您的结束语来开始我的回答,纯粹是因为它引起了我的注意(除了巨大的赏金之外)。
“Chrome 是新的违反标准的 IE 吗?还是我做错了什么可怕的事情?我很想在这一点上只使用像素来保持一致性。”
是也不是。与在任何其他主流浏览器引擎中相比,我在 WebKit 浏览器中遇到的问题更多,但在调查个别问题后,我通常发现这是因为 WebKit 比其他人更严格地遵守 W3C 提供的规则。
大多数其他浏览器引擎似乎对开发人员都非常宽容,我喜欢他们这一点,但我们不能因为遵守规则而将 WebKit 钉在十字架上。
为了将上述陈述扩展到您的问题的其余部分,我浏览了 W3C document regarding relative font lengths .在 rem 单位 的标题下,您会注意到第一行说明:
Equal to the computed value of ‘font-size’ on the root element.
不幸的是,font-size
本身对浏览器引擎的解释相对开放。
Cyrix 的回答是正确的,因为 Chrome 会根据引擎内置的 最小字体大小 调整您的字体大小。为了轻松解决您的问题,您可以使用 text-size-adjust或更新的 font-size-adjust规则你的容器元素以防止这种情况:
* { /* Replacing "*" with ".my-element" would probably be better for the rest of your site*/
-webkit-text-size-adjust: none;
-webkit-font-size-adjust: none;
}
然而,问题是旧版本的 Chrome 不接受 font-size-adjust,而新版本仅接受 font-size-adjust 并且仅在启用实验性功能时才接受。
最后,回答您的其余问题,rem
和 em
如果您正在处理实际的文本内容等,它是一个很好的度量单位。请按照以下方式思考:
<h1>
总是比正文大 25% h1 { font-size: 1.25rem; }
.header { height: 3em; }
但是,如果您正在使用需要在内部容纳指定内容 block 的容器类型 block ,那么使用更稳定的东西总是更好。请记住,稳定并不意味着 react 迟钝。
以此为例:
.my-element {
width: 95%;
margin: auto;
max-width: 600px;
}
这将使您的元素很好地 float 在页面中间,同时保持元素的大小适合其中的内容,如果屏幕尺寸减小到小于您的 .my-element
的点。高度,它会相应地调整。
关于css - 基于 Rem 的布局,在 chrome 上缩放不一致,PX 与 REM,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/44378664/
这个问题在这里已经有了答案: 关闭 10 年前。 Possible Duplicate: Recreating a Dictionary from an IEnumerable 在 Dictiona
是否可以使用命令行版本的 ImageMagick 修剪图像(比如带有 alpha 的 PNG),使输出图像的宽度和高度都是偶数(不是奇数)? 准确地说,应该先修剪输出图像,然后用透明像素填充。我需要这
我有一个订单的Map,可以由许多不同的线程访问。我想控制访问,所以考虑以下简单的数据结构+包装器。 public interface OrderContainer { boolean cont
我有以下代码,现在只是 div 中的一个 Logo ,但我正在尝试添加一些导航单元格,稍后我将对其进行样式设置。问题是,我似乎无法让它们与(除此之外) Logo “一致”,它们总是下降到下一行。我做错
关闭。这个问题需要更多focused .它目前不接受答案。 想改进这个问题吗? 更新问题,使其只关注一个问题 editing this post . 关闭 9 年前。 Improve this qu
有没有办法将种子值传递给 d3-cloud 或其他基于 javascript 的标签云,以使其在页面加载之间保持一致? 我们的客户希望使用标签云作为导航/发现辅助工具,但由于 d3-cloud 会在每
我有一条由用户使用 D3.js 绘制的路径。 我想在我的用户绘制路径上定义一个破折号数组,但是,随着它改变其形状和长度,破折号的行为不一致并且间隙在移动并变得越来越小。 这是一个代码笔: https:
只是为了研究UINavigationBar和UIStatusBar的UI,我把Navigation Bar Style改成了Black,并且取消勾选Bar visibility,即Shows Navi
我最近在我的家用机器 (OSX 10.9) 和我的远程服务器 (Ubuntu 12.04 64 位) 上安装了 unison。 我在这两个地方都安装了 2.40.102 版本。我在我的 Mac 上使用
我正在使用 migrate 创建 SQL 数据库模式并用初始数据填充它。后来使用 SQLAlchemy 来处理这个数据库。 我如何测试我的 SQLAlchemy 模型是否与 migrate 生成的真实
道歉对这一切来说还是新鲜事。我正在创建一个网页,并在两个单独的 div 中将图像和文本并排放置。我已经设法将它们放在页面上我想要的位置,但是当我调整页面大小时,文本会调整大小,但图像不会。我希望文本底
在翻阅Cassandra和HBase的阅读资料时,我发现Cassandra并不一致,但HBase是一致的。没有找到任何合适的阅读 Material 。 有人可以提供有关此主题的任何博客/文章吗? 最佳
我需要计算 MacOS 中文件夹的大小。该尺寸值必须与 Finder 一致。我尝试了几种方法来做到这一点。但结果总是与Finder不同。 以下方法是我尝试过的。 typedef struct{
问:我可以使用 C++ 中的任何编译时机制来自动验证模板类方法集是否从类特化到特化相匹配? 示例:假设我想要一个类接口(interface),它根据模板值专门化具有非常不同的行为: // forwar
我想使用 SelectKBest 选择前 K 个特征并运行 GaussianNB: selection = SelectKBest(mutual_info_classif, k=300) data_t
我想要一个位于页面中央的 div,其中包含一行(两个单词)的 h1 文本,并且该文本与 div 的长度对齐;意思是,字母留出空间(同时保持它们的大小)以占据 div 的整个宽度,并且不要超出 div。
我试图更新我的服务器,所以我通过 ssh 运行以下命令: sudo do-release-upgrade 我收到以下错误: Errors were encountered while processi
我想验证单应矩阵会给出好的结果,而这个 this answer 有答案 - 但是,我不知道如何实现答案。 那么谁能推荐我如何使用 OpenCV 计算 SVD 并验证第一个奇异值与最后一个奇异值的比率是
我最近更新到 cocoapods 0.36 并对内部规范做了一些更改,现在 podspec 不再有效。我用 0.35 验证了此规范的先前版本 (0.3.8),但使用 0.36 失败。很明显 cocoa
我有两个并排设置的 TableView ,我需要它们同时滚动。因此,当您滚动一个时,另一个也会同时滚动。 我进行了一些搜索,但找不到任何信息,但我认为这一定是有可能的。 我的 TableView 都连
我是一名优秀的程序员,十分优秀!