目录
- HTML 和 JS 内联
- CSS 内联
- 图片、字体内联
工程维护
在打包多页面应用的时候,每个页面会有一个 HTML 模版与之对应。每个 HTML 模版都会包含很多相似的内容,比如 meta 信息或 SSR 时需要用到的一些占位符。如果将 meta 代码分别复制一份放到每一个 HTML 模版里面会对代码维护造成影响。
这个时候推荐的做法是维护一份 meta.html,每个 HTML 模版将 meta.html 片段内联进去。
另一个比较常见的场景就是图片、字体等文件等内联。可能的处理:找一个在线的 base64 编码工具去将各种图片 (png、jpg、gif) 或者 字体 (ttf、otf) 编码,然后将编码后的那一长串字符串放置到代码里面去。比如这个搜索 icon 图标,这段长串的字符串放置在源代码里面根本毫无语义,而且对维护者而言也是场灾难。
// index.css
.search {
background: url() no-repeat;
}
页面加载性能
减少 HTTP 网络请求数,如果你的网站使用 HTTP2 这点的意义可能不会那么大。
将各种小图片、小字体(比如:小于 5k) 在生产环境 base64 到代码里面可以极大的减少页面的请求数量,从而提升页面的加载时间。
加载体验
HTML 和 JS 内联
使用 raw-loader
// 内联 HTML 片段
<script>$(require('raw-loader!babel-loaderl!./meta. html')</script>
// 内联 JS
<script>${require('raw-loader!babel-loader!../node_modules/lib-flexible/flexible.js')}</script>
CSS 内联
方案一:借助 style-loader
(不能和 mini-css-extract-plugin
共存)
// webpack.config.js
module.exports = {
//...
module: {
rules: [
{
test: /\\.css$/,
use: [
{
loader: 'style-loader',
options: {
insertAt: 'top', // 样式插入到 <head>
injectType: 'singletonStyleTag', // 将所有的 style 标签合并成一个
}
},
'css-loader'
]
}
]
}
}
方案二:html-inline-css-webpack-plugin
// webpack.config.js
const HTMLInlineCSSWebpackPlugin = require('html-inline-css-webpack-plugin').default
module.exports = {
//...
plugins: [
new MiniCssExtractPlugin({
filename: '[name]_[contenthash:8].css'
}),
new HtmlWebpackPlugin()
new HTMLInlineCSSWebpackPlugin()
]
}
使用 html-inline-css-webpack-plugin
需要 mini-css-extract-plugin
和 html-webpack-plugin
。
html-inline-css-webpack-plugin
需要放到 html-webpack-plugin
后面。
图片、字体内联
借助 url-loader
,可以通过配置 webpack 配置让小于 10K 的图片或字体文件在构建阶段自动 base64。