- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我有一个使用 Bootstrap 和 SASS 的 Rails 应用程序,我使用谷歌字体。
我在我的 css 文件中加载我的字体:
@import url(https://fonts.googleapis.com/css?family=Open+Sans:400,300,600,700,800);
但是当我在 Safari 中检查网络请求时,它总是说我的字体没有从缓存中加载。
我已经尝试将 WebFonts 添加到我的应用程序中,希望它能为我缓存字体,但没有成功。
有人知道如何正确缓存字体吗?
提前致谢
最佳答案
字体应该缓存,谷歌字体也应该缓存。也可以看看; https://developers.google.com/fonts/faq#Performance :
If a page uses web fonts, then the font files have to be downloaded to the site visitor's computer before they can be displayed initially. The font files are served compressed for a faster download. After that initial download, they will be cached in the browser. As the Google Fonts API becomes widely used, your visitors will be likely to already have the font you're using in their browser cache when they visit your page
你应该注意到 SASS 编译 @import url()
正好是@import url()
所以你的 sass 代码导致“正常” css import .以上也清楚地表明您的问题与 Sass 无关(或与 Rails 无关)。
CSS @import
与 url()使用 HTTP 请求将 CSS 代码从外部源加载到您的 CSS 代码中。
所以在你的情况下https://fonts.googleapis.com/css?family=Open+Sans:400,300,600,700,80
不包含您的字体,但此 URI 仅返回一些 CSS 代码。此 CSS 代码包含 @font-face
字体声明。
Google 阻止了对 fonts.googleapis.com
的请求从缓存。 @font-face
这些结果中的声明还包含 url()
请求指向字体文件。例如:src: local('Open Sans Light'), local('OpenSans-Light'), url(https://fonts.gstatic.com/s/opensans/v10/DXI1ORHCpsQm3Vp6mXoaTegdm0LZdjqr5-oayXSOefg.woff2) format('woff2'), url(https://fonts.gstatic.com/s/opensans/v10/DXI1ORHCpsQm3Vp6mXoaTXhCUOGz7vYGh680lGh-uXM.woff) format('woff');
(@import
创建一个带有 max-age=0
header 的 HTTP 请求(请参阅:What's the difference between Cache-Control: max-age=0 and no-cache? )并且 Google 不会使用 Not Modified
header 进行响应。
字体文件来自fonts.gstatic.com
应该被缓存。
如果您的问题与来自 fonts.googleapis.com
的 CSS 代码有关不是缓存,那么你是对的。但你也应该怀疑这是否是一个真正的问题。另一方面,当您的问题与来自 fonts.gstatic.com
的字体文件有关时没有缓存那么我希望你的浏览器设置阻止缓存。
当您想禁用对 fonts.googleapis.com
的 HTTP 请求时不能被缓存,你不应该使用 @import
, 但直接把 @font-face
Sass 代码中的声明。 (您可以通过在浏览器中打开 https://fonts.googleapis.com/css?family=Open+Sans:400,300,600,700,80
找到这些声明)。请注意,当字体文件位于 fonts.gstatic.com
时,上述内容将中断字体文件的下载。改变。 Google 还可以使用 fonts.googleapis.com
中的 CSS 代码吗?将用户指向最快的位置(例如基于位置)以下载字体文件(如果尚未缓存)。
关于css - Rails 谷歌字体缓存,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/27000799/
这两个包看起来非常相似: http://www.passportjs.org/packages/passport-google-oauth2/ http://www.passportjs.org/pa
我想在我的网站上添加通过 Google 和 Twitter 登录的按钮。我需要只使用应用程序的客户端而不是服务器端来完成此操作。但我没有找到任何 API。对于我发现的所有内容,我需要使用带有 key
我使用此链接通过 google plus 共享我的页面。 https://plus.google.com/share?url=http%3A%2F%2Fexample.com%2Fcompany%2
我正在尝试学习 google API,并且我的经验是使用 Python,因此我尝试使用 google api python 客户端来访问一些 google 服务,但在构建服务对象时遇到错误。 从 ap
在其实际的实时托管平台上构建实时站点的努力中,有没有办法告诉谷歌不要索引该网站?我发现了以下内容: http://support.google.com/webmasters/bin/answer.py
我正在开发一个 iOS 应用程序。当我运行用于 google+ 登录的程序时,在我点击允许访问按钮后,会显示此消息。 You've reached this page because we have
我有一个非常复杂的网站,每个页面包含 11 个 js 文件。 我最近添加了 google +1 按钮,代码如下: 这会正确显示 +1 按钮,直到我单击它。当我单击它时,出现此错误:https://
我正在尝试使用 google API 创建一个 html 文件,以便在 google MAPS 上显示 KML 文件。 这是 HTML 代码: function initMap() {
我是使用 Google Benchmark 的新手,在本地运行代码与在 Quick-Bench.com 上运行代码时,我收到了运行相同基准测试(下方)的不同结果,该基准测试使用 C++ 检索本地时间.
我已按照 Google 网站上的说明通过添加以下元标记在我的 AngularJS 网站上启用 Ajax 抓取: 呈现的内容有一些链接,如: User 1 User 2 User 3 还有一些呈现动态
通过 Google 手册实现 Google AppInvite - link . 启动 Invite Activity 并在 LogCat 中获取下一步: E/AppInviteAgent: Get
那么有人用过 Google 的 Go 吗?我想知道数学性能(例如触发器)与其他具有垃圾收集器的语言(如 Java 或 .NET)相比如何? 有人调查过吗? 最佳答案 理论性能:纯 Go 程序的理论性能
Stackdriver 测试我的网站启动速度慢 我们使用 cloudflare 作为我们的站点 CDN 提供商。我们使用 stackdriver 从外部测试站点可用性,我们将时间检查间隔设置为 1 分
我正在尝试使用 stax.GeneralConv() ( https://jax.readthedocs.io/en/latest/_modules/jax/experimental/stax.htm
我有一个从谷歌金融中提取日内数据的软件。但是,由于昨天 Google 更新了 API,所以软件报错了 Conversion from string HTML HEAD meta http-equiv=
我们在尝试从 Google 获取 oAuth token 时遇到“redirect_uri_mismatch”错误: [client 127.0.0.1:49892] {\n "error" : "
我的网站正在使用 Google reCAPTCHA 控件,但我听说它被阻止了 中国,反正我看到有人报告说将 API 更改为 https://www.recaptcha.net在中国工作? Anyone
背景 WordPress Google Adsense 谷歌自动插入 anchor 定广告 https://pptmon.com 问题 如下图所示,主播广告的容器高度太大了! 如何调整高度? 这是谷歌
我在使用 Google Colab 时遇到问题。当我想制作一个新的 Python3 Notebook 时,由于我登录了我的 Google 帐户,因此无法加载刚刚打开的新页面。 我该怎么办? 感谢您的帮
我正在使用 facebook和 google oauth2使用 passport js 登录, 有了这个流 用户点击登录按钮 重定向到 facebook/google auth 页面(取决于用户选择的
我是一名优秀的程序员,十分优秀!