vue-skeleton-webpack-plugin
// 安装骨架屏插件 npm install vue-skeleton-webpack-plugin // 再src目录下新建一个skeleton目录来存放骨架屏组件,新建skeleton1.vue <template> <div class="skeleton-wrapper"> <section class="skeleton-block"> <img src=""> <img src=""> </section> </div> </template> <style scoped lang="less"> .skeleton-block { display: flex; flex-direction: column; padding-top: 8px; } </style> // 同时在src目录下新建skeleton.js文件 import Vue from 'vue' import skeleton from './skeleton' export default new Vue({ components: { skeleton, skeleton1 }, template: ` <div> <skeleton id="skeleton" style="display:none;" /> </div> ` }) // 在vue.config.js中配置 const path = require('path') const SkeletonWebpackPlugin = require('vue-skeleton-webpack-plugin') module.exports = { configureWebpack: (config)=>{ config.plugins.push(new SkeletonWebpackPlugin({ webpackConfig: { entry: { app: path.join(__dirname, './src/skeleton.js'), }, }, minimize: true, quiet: true, // 如果不设置那么所有的路由都会共享这个骨架屏组件 router: { mode: 'hash', // 给对应的路由设置对应的骨架屏组件,skeletonId的值根据组件设置的id routes: [ { path: '/key', skeletonId: 'skeleton' } ] } })) }, }