Skeleton 骨架屏

文章目录

    • 前言
    • 步骤
      • [1. 了解基本结构](#1. 了解基本结构)
      • [2. 包裹结构](#2. 包裹结构)
      • [3. 使用loading变量控制好显示和隐藏就好。](#3. 使用loading变量控制好显示和隐藏就好。)
    • 效果

前言

在需要等待加载内容的位置设置一个骨架屏,某些场景下比 Loading 的视觉效果更好。

步骤

1. 了解基本结构

使用Skeleton前要了解基本使用元素。

  • 外层标签"el-skeleton"
  • <template #template>
  • <el-skeleton-item>
  • 实际的展示层

2. 包裹结构

<template>
	<el-skeleton :loading="loading" animated style="width: 240px">
		<!-- 骨架屏的控制 -->
		<template #template>
			<el-skeleton-item variant="image" style="width: 240px; height: 240px" />
			<div style="padding: 14px">
				<el-skeleton-item variant="h3" style="width: 50%" />
			</div>
		</template>
		<!-- 真正渲染的DOM -->
		<div class="model-items">
			......
		</div>
	</el-skeleton>
</template>

3. 使用loading变量控制好显示和隐藏就好。

补充:大部分人会遇到这种报错

'v-slot' directive must be owned by a custom element, but 'template' is not. eslint(vue/valid-v-slot)
[vue/valid-v-slot] 'v-slot' directive must be owned by a custom element, but 'template' is not. eslint-plugin-vue

原因:报错原因是 <template #default> 使用了 v-slot 指令,但 template 标签本身不是自定义元素。根据 Vue 的规范,v-slot 必须绑定在自定义组件上,而不能直接用在普通的 template 标签上。

解决办法:直接移除真正渲染的DOM上的#default

效果

由于自己的网站涉及到客户私密,所以就用demo图片展示一下

相关推荐
离别又见离别16 分钟前
vue3-sfc-loader 加载远程.vue文件(sfc)案例
java·前端·vue.js
BillKu18 分钟前
在Vue中,<img> 标签的 src 值
vue.js
凡大来啦44 分钟前
Axios发起HTTP请求时的先后执行顺序
前端·javascript·http
ᥬ 小月亮1 小时前
Js:DOM中的样式(包含行内样式、滚动样式、可见区域样式等)
开发语言·javascript·ecmascript
16年上任的CTO1 小时前
一文大白话讲清楚webpack基本使用——4——vue-loader的配置和使用
前端·javascript·webpack·ecmascript·vue-loader·vueloaderplugin
软件工程师文艺2 小时前
使用HTML5 Canvas 实现呼吸粒子球动画效果的原理
前端·javascript·html·html5
不在··3 小时前
Axios HTTP库基础教程:从安装到GET与POST请求的实现
前端·javascript·vue.js
少油少盐不要辣10 小时前
js截取video视频某一帧为图片
javascript·音视频
罗_三金11 小时前
(4)Vue 3 + Vite + Axios + Pinia + Tailwind CSS搭建一个基础框架
前端·css·vue.js·axios·pinia·tailwind
zqwang88811 小时前
IOS 安全机制拦截 window.open
前端·javascript