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' }
]
}
}))
},
}