- 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"
我在一个小型大写字母很重要的网站上工作:设置圣经的文本。在旧约中,上帝的名字被音译为Lord
但在小盘股中——不是 LORD
.但是,目前 OpenType 小型大写字母支持的状态……不是最佳状态。 Safari(甚至通过 Yosemite 上的 Safari 8,我正在输入此内容)仍然不支持 -webkit-font-feature-settings: 'smcp'
选项,并且该网站的很多点击量都将来自移动设备。
不幸的是,“优雅降级”在这里是有问题的:如果您同时指定 font-variant: small-caps
和 font-feature-settings: 'smcp'
在支持后者的浏览器(例如 Chrome)中,font-variant
声明覆盖了它,所以丑陋的旧式版本仍然发挥作用。 (注意:按照 spec 应该是这样:font-variant
声明的优先级高于 font-feature-settings
声明)。鉴于 font-variant: small-caps
的当前实现,虽然 - 缩小的大写而不是实际的小写 - 结果是使用 font-variant: small-caps
现实主义者不太优雅地降低了每个人的阅读体验。
过去,我将小型大写字母导出为不同的 webfont 并直接指定它们;见 this post举一个简单的例子:每段的第一行都是这样指定的。
虽然我可以在这里做同样的事情(至少理论上可以提供一个非常小的字体,因为我真的只需要三个字符: o
、 r
和 d
),我更喜欢简单地启用理智的回退。然而,如上所述,这是不可能的。我愿意但更愿意避免将服务器端解决方案(浏览器检测等)作为一个更好地最小化的复杂点,尤其是考虑到浏览器的变化如此之快。还有什么办法可以解决这个问题,尤其是有没有现有的解决方案?
编辑:根据评论澄清—— future ,font-variant: small-caps
将很好地处理这个问题,根据规范,如果字体提供它,它应该显示字体的小写字母变体。然而,目前,没有浏览器支持这个(至少,我找不到!)。这意味着相反,它们都只是通过缩小实际大写字母来呈现假小写字母。结果在排版上令人不快,并且在这个元素中是 Not Acceptable 。
最佳答案
最后更新 2016/02/28。
我花了相当多的时间研究这个问题并与它搏斗。
在尽我所能挖掘之后,现在的最佳解决方案是:@supports
利用 @supports
浏览器中的规则。这是我最初的
选择做这个元素。 [1]您可以这样使用规则:
.some-class {
font-variant: small-caps;
}
@supports(font-feature-settings: 'smcp') {
.some-class {
font-variant: normal;
font-feature-settings: 'smcp';
}
}
我通过省略前缀版本进行了简化;你需要添加
-webkit-
和
-moz-
前缀以使其实际工作。
更新,-moz-
前缀,这将在
@supports
规则非常相似:
@supports
:Can I Use Feature Queries? : Chrome 31+, 火狐@supports
支持。font-feature-settings
:Using Small Caps & Text Figures on the Web :@supports
,你错过了一个
@supports
,但 Edge 12+
font-variant: small-caps
默认使用 OpenType 小型大写字母,
.divine-name {
font-family: 'my_typeface_smcp', 'my_typeface', serif;
}
这种方法的主要优点是一致性:该字体将
@font-face
所需的各种钩子(Hook).
font-feature-settings: 'smcp'
方法有一些letter-spacing
(一个比较常见的If you have a font with OpenType features, you can now flatten some ofthem into your webfont. For instance, some fonts have small caps built in,but they are completely inaccessible in a web browser. By selecting the"Small Cap" option, the Generator will replace all the lowercase glyphswith the small cap variants, giving you a small cap font. Please note thatnot all OpenType features are supported and if the font lacks OpenTypefeatures, using these options won't create them.
关于OpenType 小型大写字母的 CSS 回退,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/24846264/
假设我这样做: SELECT * FROM table WHERE field2 = '2019@162440' OR field2 LIKE '%%2019@%%'; 在这种情况下,它会尝试同时执行
我正在研究背景大小有几个原因,但主要是因为通过使用它我可以使用 Sprite 和我可以使这些图像响应。当然,问题出在较旧的浏览器上,例如 IE8 及更低版本。 我希望我可以使用 polyfill但是这
我在单个 sprite 图像中包含页面上的许多图像,由于网站的其他要求,这些图像必须包含在单个 sprite 中。 虽然这在大多数浏览器中工作正常,但我在 Opera Mini 上遇到了一个问题,它根
我使用 CSS3 制作了一个圆圈,但在旧版浏览器(ie7 等)中出现了问题,圆圈显示为正方形。 我知道我可以使用背景图片作为备份,但这不是违背了使用代码的意义吗? 如果我要放入背景图像,它会放在 CS
关闭。这个问题需要更多focused .它目前不接受答案。 想改进这个问题吗? 更新问题,使其只关注一个问题 editing this post . 关闭 8 年前。 Improve this qu
我在 iOS 应用程序中使用 stringsdict 功能进行本地化。该应用程序是英文的,正在本地化为法语。因此,我有一个英语版本作为基础,一个法语版本用于翻译。 如果作为用户,我将我的语言设置为其他
使用 .css() 进行回退的正确方法是什么?这最常用于字体后备,但我将它用于光标图像。 这是我得到的不起作用的东西: $("#dragable").css('cursor','url(images/
我正在使用 CDN 加载 Bootstrap.css。 我的问题是如何检查 CDN bootstrap 是否已加载/找到。 如果不是,则加载本地 Boostrap。 这是 Jquery 后备..
我是 NGINX 的新手,正在迁移服务器。我还没有完成新服务器上的所有内容,所以我希望它与新服务器匹配,除非该资源或路径不存在。如果是这样,我想将其发送到旧服务器。有没有办法做到这一点? 最佳答案 我
这是一个经典的后备解决方案。如果第一个 el 没有被渲染,那么它会使用其他渲染器重试。如何最好地重构它? 这段代码的问题在于: 渲染器需要位于数组中,但在这里,它们位于 then block 中。 当
我正在设置一个可变参数模板函数,以便能够在特定系列的类上调用各种函数重载。到目前为止,我已经能够在将不受支持的类传递给函数时“中断”编译,但我希望能够提供有效的回退以在运行时处理“不受支持”的情况。
我正在尝试在表单提交上创建一个 JSON 对象以传递给 Perl。我有几个嵌套的 div 和 ul 和 li 来允许 jQuery-ui 可排序。 为了能够保存排序后的 li(分布在多个 div 上)
ASP.NET 对于我使用的每个 appSetting,我想指定一个值,如果在 appSettings 中找不到指定的键,该值将被返回。我正要创建一个类来管理这个,但我认为这个功能可能已经在 .NET
我刚开始使用 ApacheKafka。我设置了整个事情,现在我试图在现有的 Java 应用程序中通过日志附加器引入 Kafka 发送日志。此应用程序使用 Logback 作为记录器库。所以,我猜,这让
回退 document.addEventListener('DOMContentLoaded',function(){/*code here*/}) 最佳答案 来自 MDN : Internet Ex
我一直在尝试编译一个 Android 应用程序,但我收到错误提示 java: non-static method canGoBack() cannot be referenced from a sta
我查看了无数答案并尝试了所有方法(似乎),但我仍然无法放松身心。 我有一个 Storyboard序列: 导航 Controller -> 主界面 Controller -> 导航 Controller
您知道是否有一种方法可以将媒体查询的完全相同的内容渲染到 LESS 中的类中? 为了解释我的情况:我先做移动,并试图避免被媒体查询覆盖。不幸的是,这最终排除了 ie8 及以下版本,因为大多数桌面样式都
有人建议我通过“@support”以下列方式组合 css-grid 和 css-table:支持网格的浏览器应该使用网格,不支持网格的浏览器回退到默认的表格样式。 现在看来,我的网格布局无法建立,即使
MathML是一种编写数学的网络标准,可以轻松缩放而无需像素化(就像 SVG)、复制和粘贴以及屏幕阅读器阅读。 Chrome 拒绝在存在 JavaScript polyfill 的基础上实现它。 (I
我是一名优秀的程序员,十分优秀!