在Chrome扩展的Content Scripts中使用@font-face
在 《Chrome扩展中使用Vuejs》 文章中,我们提到过 @font-face 我是用的 CDN 的方式来搞定的。但是用 CDN 的缺点就是网络不畅的时候,扩展中使用 @font-face 的地方显示就是个方块了。
为了解决这个问题,我搜索了下,找到了解决方案。
这里面有几个要点,一个是字体文件可以在任意页面访问到,一个是如何获取到扩展ID。
正常情况下,扩展的资源文件是与所有网页隔离开的,扩展相当于是在一个沙盒里面运行,如果想要在 Content Scripts 模式下,让 JS 或者 CSS 文件访问到扩展中的资源文件,那么就需要在 manifest.json 中增加配置项 web_accessible_resources。
1 | "web_accessible_resources": ["fonts/*"] |
就像上面这样增加配置后,我们就可以在 Content Scripts 模式下访问到 fonts/ 目录下的所有资源文件了。
再来说下第二个问题。
我们知道扩展的地址结构是 chrome://[扩展ID],那么我们的 CSS 文件中的 @font-face 的路径中的扩展ID该怎么获取呢?
通过看文档,找到了预设值 __MSG_@@extension_id__,这是出处:https://developer.chrome.com/extensions/i18n#overview-predefined
那么我们去修改下 element-variables.scss 中的 font-path 像这样:
1 | $--font-path: 'chrome-extension://__MSG_@@extension_id__/fonts'; |
这样,最关键的两个问题就解决了,最后只要在 webpack.config.js 中需要复制的操作里,增加复制字体文件的操作即可,就像这样:
1 | new CopyPlugin([ |
通过这样设置后,我们通过扩展插入到网页中的 CSS 文件就能直接访问到扩展中的资源文件了。