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 } }