在原生APP中我們經常可以看到,打開app時候,內容還沒出來,app會被別的內容替代,這樣很好的提升了用戶體驗。那么在webApp中,我們如何避免白屏的尷尬情況呢?可以通過 vue-skeleton-webpack-plugin這個插件來實現類似的效果。
1.首先需要安裝這個插件 npm install vue-skeleton-webpack-plugin -S
2.我們在src目錄下創建 Skeleton.vue
<template> <div class="skeleton-wrapper"> <header class="skeleton-header"></header> <section class="skeleton-block"> <img src=""> <img src=""> </section> </div> </template> <script> export default { name: 'skeleton' } </script> <style scoped> .skeleton-header { height: 40px; background: #1976d2; padding:0; margin: 0; width: 100%; } .skeleton-block { display: flex; flex-direction: column; padding-top: 8px; } </style>
3.創建入口文件:entry-skeleton.js
import Vue from 'vue' import Skeleton from './Skeleton' export default new Vue({ components: { Skeleton }, template: '<Skeleton />' })
4.我們在build 目錄下創建 webpack.skeleton.conf.js
'use strict'; const path = require('path') const merge = require('webpack-merge') const baseWebpackConfig = require('./webpack.base.conf') const nodeExternals = require('webpack-node-externals') function resolve(dir) { return path.join(__dirname, dir) } module.exports = merge(baseWebpackConfig, { target: 'node', devtool: false, entry: { app: resolve('../src/entry-skeleton.js') }, output: Object.assign({}, baseWebpackConfig.output, { libraryTarget: 'commonjs2' }), externals: nodeExternals({ whitelist: /\.css$/ }), plugins: [] })
在后在webpack.dev.conf.js和webpack.prod.conf.js分別引入 webpack.skeleton.conf.js
new SkeletonWebpackPlugin({ webpackConfig: require('./webpack.skeleton.conf'), quiet: true })
這樣大功告成,我們在頁面加載比較慢的時候不至於出現白屏的尷尬狀況了。