这是一个基于 Vue 的 webpack 插件,为单页/多页应用生成骨架屏 skeleton,减少白屏时间,在页面完全渲染之前提升用户感知体验。
参考了饿了么的 PWA 升级实践一文, 使用服务端渲染在构建时渲染 skeleton 组件,将 DOM 和样式内联到最终输出的 html 中。
另外,为了开发时调试方便,会将对应路由写入router.js
中,可通过/skeleton
路由访问。
插件具体实现可参考我的这篇文章
安装:
npm install vue-skeleton-webpack-plugin
运行测试用例:
npm run test
在 webpack 中引入插件:
// webpack.conf.js
import SkeletonWebpackPlugin from 'vue-skeleton-webpack-plugin';
plugins: [
new SkeletonWebpackPlugin({
webpackConfig: {
entry: {
app: resolve('./src/entry-skeleton.js')
}
}
})
]
在单页应用中开发模式下自动插入路由规则:
// webpack.dev.conf.js
import SkeletonWebpackPlugin from 'vue-skeleton-webpack-plugin';
module: {
rules: [
SkeletonWebpackPlugin.loader({
resource: resolve('src/entry.js'),
options: {
entry: 'skeleton',
routePathTemplate: '/skeleton',
importTemplate: 'import Skeleton from \'./Skeleton.vue\';'
}
})
]
}
- webpackConfig 必填,渲染 skeleton 的 webpack 配置对象
- insertAfter 选填,渲染 DOM 结果插入位置,默认值为
'<div id="app">'
- quiet 选填,在服务端渲染时是否需要输出信息到控制台
- router 选填 SPA 下配置各个路由路径对应的 Skeleton
- mode 选填 路由模式,两个有效值
history|hash
- routes 选填 路由数组,其中每个路由对象包含两个属性:
- path 路由路径
- skeletonId Skeleton DOM 的 id
- mode 选填 路由模式,两个有效值
- minimize 选填 SPA 下是否需要压缩注入 HTML 的 JS 代码
参数分为两类:
- webpack模块规则,skeleton 对应的路由将被插入路由文件中,所以需要指定一个或多个路由文件,使用
resource/include/test
皆可指定 loader 应用的文件。 options
将被传入 loader 中的参数对象,包含以下属性:- entry 必填,支持字符串和数组类型,对应页面入口的名称
- importTemplate 选填,引入 skeleton 组件的表达式,默认值为
'import [nameCap] from \'@/pages/[nameCap].vue\';'
- routePathTemplate 选填,路由路径,默认值为
'/skeleton-[name]'
- insertAfter 选填,路由插入位置,默认值为
'routes: ['
在importTemplate
和routePathTemplate
中可以使用以下占位符:
[name]
和entry
保持一致[nameCap]
entry
首字母大写[nameHash]
使用entry
名称生成 hash,避免名称中包含例如连字符的情况
例如使用以下配置,将向路由文件中插入'import Page1 from \'@/pages/Page1.vue\';'
和'import Page2 from \'@/pages/Page2.vue\';'
两条语句。同时生成/skeleton-page1
和/skeleton-page2
两条路由规则。
{
entry: ['page1', 'page2'],
importTemplate: 'import [nameCap] from \'@/pages/[nameCap].vue\';',
routePathTemplate: '/skeleton-[name]'
}
如果你的项目是使用 Lavas 创建的,可参考Lavas Appshell模版和Lavas MPA模版 中的应用。
如果你的项目是使用 vue-cli 创建的,可以参考基于 Vue Webpack 模板应用这个插件的例子: SPA 中单个 Skeleton:
SPA 中多个 Skeleton:
或者你可以参考examples下的测试用例,其中也包含了单页和多页情况。
运行出现如下错误:
node_modules\memory-fs\lib\MemoryFileSystem.js:114 throw new MemoryFileSystemError(errors.code.ENOENT, _path);
由于插件使用了 Vue 服务端渲染在构建时渲染 skeleton 组件,将 DOM 和样式内联到最终输出的 html 中。 因此在给 skeleton 使用的 Webpack 配置对象中需要开启样式分离,将 skeleton 使用的样式从 JS 中分离出来。
在 Webpack 中样式分离是通过 extract-text-webpack-plugin 插件实现的。因此在 webpack.skeleton.config
中必须正确配置该插件。
以使用 vue-cli 创建的项目为例,如果你的 webpack.skeleton.conf
继承自 webpack.base.conf
,在开发模式下是默认关闭样式分离的,因此需要修改,可参考修改方案。