1.安装
npm install vue-skeleton-webpack-plugin
2.创建骨架屏文件
在src文件夹下新建skeleton目录,并在这个目录内新建listSkeleton.vue、detailSkeleton.vue

3.detailSkeleton.vue
<!-- detailSkeleton.vue --> <template> <div class="container"> 详情骨架屏 <img src="" /> </div> </template> <script> export default { components: {}, data () { return {} }, mounted () {}, methods: {} } </script> <style scoped lang="scss"> </style>
4.listSkeleton.vue
<!--listSkeleton.vue -->
<template>
<div class="container">
<div>列表骨架屏</div>
<img
src=""
/>
<img
src=""
/>
</div>
</template>
<script>
export default {
components: {},
data() {
return {};
},
mounted() {},
methods: {},
};
</script>
<style scoped lang="scss">
</style>
5.在main.js同级新建一个Skeleton.js

内容如下:
// skeleton.js import Vue from 'vue' import listSkeleton from './skeleton/listSkeleton' import detailSkeleton from './skeleton/detailSkeleton' export default new Vue({ components: { listSkeleton, detailSkeleton }, template: ` <div> <listSkeleton id="listSkeleton" style="display:none;" /> <detailSkeleton id="detailSkeleton" style="display:none;" /> </div> ` })
6.配置vue.config.js,PrerenderSPAPlugin是预渲染插件配置,SkeletonWebpackPlugin是骨架屏插件配置
const PrerenderSPAPlugin = require('prerender-spa-plugin');
const SkeletonWebpackPlugin = require('vue-skeleton-webpack-plugin')
const Renderer = PrerenderSPAPlugin.PuppeteerRenderer;
const path = require('path');
// vue.config.js
module.exports = {
configureWebpack: config => {
if (process.env.NODE_ENV !== 'production') return;
return {
plugins: [
new PrerenderSPAPlugin({
staticDir: path.join(__dirname, 'dist'),
routes: ['/', '/Second', '/Detail'],
renderer: new Renderer({
inject: {
foo: "bar"
},
headless: false,
renderAfterDocumentEvent: 'render-event'
})
}),
// 骨架屏
new SkeletonWebpackPlugin({
webpackConfig: {
entry: {
app: path.join(__dirname, './src/Skeleton.js')
}
},
minimize: true,
quiet: true,
router: {
mode: 'hash',
routes: [
{ path: /^/Second/, skeletonId: 'listSkeleton' },
{ path: /^/Detail/, skeletonId: 'detailSkeleton' }
] } }) ] } }, css: { // 是否使用css分离插件 ExtractTextPlugin extract: true, // 开启 CSS source maps? sourceMap: false, // 启用 CSS modules for all css / pre-processor files. modules: false } }