脚手架不说了,提前搭建好
然后安装 vue-skeleton-webpack-plugin
npm install vue-skeleton-webpack-plugin
创建文件 skeleton.js和skeleton.vue
skeleton.js
import Vue from 'vue' import Skeleton from './Skeleton.vue' export default new Vue({ components: { Skeleton }, template: '<skeleton />' })
skeleton.vue
我的skeleton.vue不知为何<style>标签写在外部没有加载进去,故写到<template>内
样式和模板可以自己修改
<template> <div class="skeleton-wrapper"> <style> .skeleton { padding: 10px; } .skeleton .skeleton-head, .skeleton .skeleton-title, .skeleton .skeleton-content-bottom, .skeleton .skeleton-content { background: rgba(194, 207, 214,.5); background-image: linear-gradient(90deg,rgba(255, 255, 255, 0.15) 25%, transparent 25%); background-size: 20rem 20rem; animation: skeleton-stripes 1s linear infinite; margin: 0 auto 30px; text-align: center; color: darkgray; } .skeleton-head { width: 100px; height: 60px; float: left; } .skeleton-body { margin-left: 110px; } .skeleton-title { width: 90%; height: 60px; line-height: 60px; } .skeleton-content { width: 60%; height: 40px; background: rgba(194, 207, 214,.3)!important; } .skeleton-content-bottom { width: 40%; height: 40px; margin: 0 auto 30px 20%!important; background: rgba(194, 207, 214,.3)!important; } @keyframes skeleton-stripes { from { background-position: 0 0 ; } to { background-position: 20rem 0; } } </style> <header class="skeleton-header"></header> <section class="skeleton-block"> <div class="skeleton"> <div class="skeleton-head"></div> <div class="skeleton-body"> <div class="skeleton-title">加载中</div> <div class="skeleton-content"></div> <div class="skeleton-content-bottom"></div> <div class="skeleton-content"></div> <div class="skeleton-content-bottom"></div> <div class="skeleton-content"></div> <div class="skeleton-content-bottom"></div> <div class="skeleton-content"></div> <div class="skeleton-content-bottom"></div> <div class="skeleton-content"></div> </div> </div> </section> </div> </template> <script> export default { name: 'skeleton' } </script>
在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: { //指向自己的skeleton.js路径 app: resolve('../src/renderer/skeleton/skeleton.js') }, output: Object.assign({}, baseWebpackConfig.output, { libraryTarget: 'commonjs2' }), externals: nodeExternals({ whitelist: /\.css$/ }), plugins: [] })
大功告成
vue-skeleton-webpack-plugin 可以 使用多个 骨架屏 ,具体的可以查看官网地址: https://github.com/lavas-project/vue-skeleton-webpack-plugin
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件!
如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com
暂无“vue-cli 构建骨架屏的方法示例”评论...
更新动态
2025年01月15日
2025年01月15日
- 小骆驼-《草原狼2(蓝光CD)》[原抓WAV+CUE]
- 群星《欢迎来到我身边 电影原声专辑》[320K/MP3][105.02MB]
- 群星《欢迎来到我身边 电影原声专辑》[FLAC/分轨][480.9MB]
- 雷婷《梦里蓝天HQⅡ》 2023头版限量编号低速原抓[WAV+CUE][463M]
- 群星《2024好听新歌42》AI调整音效【WAV分轨】
- 王思雨-《思念陪着鸿雁飞》WAV
- 王思雨《喜马拉雅HQ》头版限量编号[WAV+CUE]
- 李健《无时无刻》[WAV+CUE][590M]
- 陈奕迅《酝酿》[WAV分轨][502M]
- 卓依婷《化蝶》2CD[WAV+CUE][1.1G]
- 群星《吉他王(黑胶CD)》[WAV+CUE]
- 齐秦《穿乐(穿越)》[WAV+CUE]
- 发烧珍品《数位CD音响测试-动向效果(九)》【WAV+CUE】
- 邝美云《邝美云精装歌集》[DSF][1.6G]
- 吕方《爱一回伤一回》[WAV+CUE][454M]