骨架屏组件

一般情况下,在首屏数据未拿到之前,为了提升用户的体验,会在页面上展示一个loading的图层,但是会有一段时间显示白屏;
因此为了更进一步优化用户体验,就有了骨架屏;在页面数据尚未加载前先给用户展示出页面的大致结构,直到请求数据返回后再渲染页面,补充进需要显示的数据内容。具体代码点击查看骨架屏组件代码及实例
或者在微信小程序开发工具导入ID ARTPbdmF7zdlI
效果图如下:
加载中…
在这里插入图片描述
加载完成
在这里插入图片描述

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
在Vue中,可以使用第三方库vue-skeleton-webpack-plugin来实现骨架。以下是一个简单的示例: 1. 安装vue-skeleton-webpack-plugin库: ```bash npm install vue-skeleton-webpack-plugin --save-dev ``` 2. 在vue.config.js中配置插件: ```js const SkeletonWebpackPlugin = require('vue-skeleton-webpack-plugin'); module.exports = { configureWebpack: { plugins: [ new SkeletonWebpackPlugin({ webpackConfig: require('path/to/your/webpack.config'), quiet: true, minimize: true, router: { mode: 'hash', routes: [ { path: '/', skeletonId: 'skeleton-home' }, { path: '/about', skeletonId: 'skeleton-about' }, ] } }) ] } } ``` 这里配置了插件的相关选项,包括webpackConfig(指定webpack配置文件)、quiet(是否开启静默模式)、minimize(是否压缩骨架代码)和router(指定骨架对应的路由信息)等。 3. 在组件中使用骨架: ```vue <template> <div> <div v-if="$skeletonId === 'skeleton-home'"> <SkeletonHome /> </div> <div v-else> <!-- 实际内容 --> </div> </div> </template> <script> import SkeletonHome from '@/components/SkeletonHome.vue'; export default { components: { SkeletonHome } } </script> ``` 这里使用了$v-skeleton-id指令来判断当前组件是否需要显示骨架,如果需要,则渲染对应的骨架组件SkeletonHome。 在SkeletonHome组件中,可以自定义骨架的样式和内容,例如: ```vue <template> <div class="skeleton-home"> <div class="skeleton-header"></div> <div class="skeleton-content"> <div class="skeleton-item"></div> <div class="skeleton-item"></div> <div class="skeleton-item"></div> </div> </div> </template> <style scoped> .skeleton-home { background-color: #f2f2f2; border-radius: 5px; padding: 20px; } .skeleton-header { height: 50px; width: 100%; background-color: #ddd; border-radius: 5px; margin-bottom: 20px; } .skeleton-content { display: flex; flex-direction: column; } .skeleton-item { height: 20px; width: 100%; background-color: #ddd; border-radius: 5px; margin-bottom: 10px; } </style> ``` 这里的骨架和之前的示例很类似,只是把HTML和CSS放到了组件中。在实际使用中,可以根据不同的需求和布局进行调整。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

刘家军

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值