骨架屏就是在頁面還沒有加載以前先給用戶展現出頁面的大體結構,直到頁面請求數據後渲染頁面。
骨架屏和loading相比較仍是骨架屏用戶體驗感更好。css
1.安裝插件html
npm install vue-skeleton-webpack-plugin --save
2.在src目錄下建立 skeleton.vuevue
<template> <div class="skeleton-wrapper"> <section class="skeleton-block"> <img src=""> <img src=""> </section> </div> </template> <script> export default { name: 'skeleton' }; </script> <style scoped> .skeleton-block { display: flex; flex-direction: column; padding-top: 8px; } </style>
3.在src目錄下建立entry-skeleton.js文件node
import Vue from 'vue' // 建立的骨架屏 Vue 實例 import skeleton from './skeleton'; export default new Vue({ components: { skeleton }, template: '<skeleton />' });
4.在build目錄下建立 webpack.skeleton.conf.jswebpack
'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: [] })
5.在webpack.dev.conf.js和webpack.prod.conf.js引入webpack.skeleton.conf.jsgit
const SkeletonWebpackPlugin = require('vue-skeleton-webpack-plugin') new SkeletonWebpackPlugin({ webpackConfig: require('./webpack.skeleton.conf'), quiet: true })
完成以上步驟就能夠實現骨架屏了,可是頁面結構改變都須要UI配合製做頁面結構的圖片,不是很理想github
在打包過程當中由於css分離致使打包失敗
目前的解決方法是在webpack.prod.conf.js文件裏面把 extract和usePostCSS改成false
rules: utils.styleLoaders({ sourceMap: config.build.productionSourceMap, extract: false, usePostCSS: false })
使用餓了麼團隊骨架屏的方案 page-skeleton-webpack-pluginweb
安裝插件vue-cli
npm install page-skeleton-webpack-plugin --save
插件使用方法:插件使用文檔npm
目前存在的問題:能成功構建骨架屏,可是沒法在項目體現出來,(多是bug)有待餓了麼團隊修復。若是可以修復的話仍是很是想使用這個方案來實現骨架屏。
參考文章:vue-cli的項目加入骨架屏