265 lines
6.2 KiB
Plaintext
265 lines
6.2 KiB
Plaintext
<template>
|
|
<view class="skeleton-profile">
|
|
<!-- 用户信息骨架 -->
|
|
<view class="skeleton-user-header">
|
|
<view class="skeleton-avatar"></view>
|
|
<view class="skeleton-user-info">
|
|
<view class="skeleton-name"></view>
|
|
<view class="skeleton-id"></view>
|
|
</view>
|
|
</view>
|
|
|
|
<!-- 统计卡片骨架 -->
|
|
<view class="skeleton-stats-card">
|
|
<view class="skeleton-stats-item">
|
|
<view class="skeleton-stats-icon"></view>
|
|
<view class="skeleton-stats-content">
|
|
<view class="skeleton-stats-value"></view>
|
|
<view class="skeleton-stats-label"></view>
|
|
</view>
|
|
</view>
|
|
<view class="skeleton-divider"></view>
|
|
<view class="skeleton-stats-item">
|
|
<view class="skeleton-stats-icon"></view>
|
|
<view class="skeleton-stats-content">
|
|
<view class="skeleton-stats-value"></view>
|
|
<view class="skeleton-stats-label"></view>
|
|
</view>
|
|
</view>
|
|
</view>
|
|
|
|
<!-- 会员码骨架 -->
|
|
<view class="skeleton-member-code"></view>
|
|
|
|
<!-- 功能入口骨架 -->
|
|
<view class="skeleton-function-grid">
|
|
<view v-for="i in 4" :key="i" class="skeleton-function-item">
|
|
<view class="skeleton-function-icon"></view>
|
|
<view class="skeleton-function-name"></view>
|
|
</view>
|
|
</view>
|
|
|
|
<!-- 菜单列表骨架 -->
|
|
<view class="skeleton-menu">
|
|
<view v-for="i in 3" :key="i" class="skeleton-menu-item">
|
|
<view class="skeleton-menu-icon"></view>
|
|
<view class="skeleton-menu-text"></view>
|
|
<view class="skeleton-menu-arrow"></view>
|
|
</view>
|
|
</view>
|
|
</view>
|
|
</template>
|
|
|
|
<script setup>
|
|
</script>
|
|
|
|
<style lang="scss" scoped>
|
|
.skeleton-profile {
|
|
min-height: 100vh;
|
|
background: #F5F5F5;
|
|
padding-bottom: calc(100rpx + env(safe-area-inset-bottom));
|
|
}
|
|
|
|
/* 用户信息骨架 */
|
|
.skeleton-user-header {
|
|
background: linear-gradient(135deg, #FFF4E6, #FFE0B2);
|
|
padding: 20rpx 20rpx 50rpx;
|
|
display: flex;
|
|
align-items: center;
|
|
}
|
|
|
|
.skeleton-avatar {
|
|
width: 120rpx;
|
|
height: 120rpx;
|
|
border-radius: 60rpx;
|
|
background: linear-gradient(90deg, #f0f0f0 25%, #e0e0e0 50%, #f0f0f0 75%);
|
|
background-size: 200% 100%;
|
|
animation: loading 1.5s ease-in-out infinite;
|
|
margin-right: 20rpx;
|
|
flex-shrink: 0;
|
|
}
|
|
|
|
.skeleton-user-info {
|
|
flex: 1;
|
|
}
|
|
|
|
.skeleton-name {
|
|
height: 36rpx;
|
|
width: 200rpx;
|
|
border-radius: 4rpx;
|
|
background: linear-gradient(90deg, #f0f0f0 25%, #e0e0e0 50%, #f0f0f0 75%);
|
|
background-size: 200% 100%;
|
|
animation: loading 1.5s ease-in-out infinite;
|
|
margin-bottom: 10rpx;
|
|
}
|
|
|
|
.skeleton-id {
|
|
height: 32rpx;
|
|
width: 240rpx;
|
|
border-radius: 4rpx;
|
|
background: linear-gradient(90deg, #f0f0f0 25%, #e0e0e0 50%, #f0f0f0 75%);
|
|
background-size: 200% 100%;
|
|
animation: loading 1.5s ease-in-out infinite;
|
|
}
|
|
|
|
/* 统计卡片骨架 */
|
|
.skeleton-stats-card {
|
|
background: #FFFFFF;
|
|
margin: -20rpx 0 20rpx;
|
|
border-radius: 0;
|
|
border-top-left-radius: 24rpx;
|
|
border-top-right-radius: 24rpx;
|
|
padding: 24rpx;
|
|
display: flex;
|
|
justify-content: space-around;
|
|
}
|
|
|
|
.skeleton-stats-item {
|
|
flex: 1;
|
|
display: flex;
|
|
align-items: center;
|
|
justify-content: center;
|
|
gap: 16rpx;
|
|
}
|
|
|
|
.skeleton-stats-icon {
|
|
width: 64rpx;
|
|
height: 64rpx;
|
|
border-radius: 12rpx;
|
|
background: linear-gradient(90deg, #f0f0f0 25%, #e0e0e0 50%, #f0f0f0 75%);
|
|
background-size: 200% 100%;
|
|
animation: loading 1.5s ease-in-out infinite;
|
|
flex-shrink: 0;
|
|
}
|
|
|
|
.skeleton-stats-content {
|
|
display: flex;
|
|
flex-direction: column;
|
|
gap: 4rpx;
|
|
}
|
|
|
|
.skeleton-stats-value {
|
|
height: 36rpx;
|
|
width: 60rpx;
|
|
border-radius: 4rpx;
|
|
background: linear-gradient(90deg, #f0f0f0 25%, #e0e0e0 50%, #f0f0f0 75%);
|
|
background-size: 200% 100%;
|
|
animation: loading 1.5s ease-in-out infinite;
|
|
}
|
|
|
|
.skeleton-stats-label {
|
|
height: 24rpx;
|
|
width: 48rpx;
|
|
border-radius: 4rpx;
|
|
background: linear-gradient(90deg, #f0f0f0 25%, #e0e0e0 50%, #f0f0f0 75%);
|
|
background-size: 200% 100%;
|
|
animation: loading 1.5s ease-in-out infinite;
|
|
}
|
|
|
|
.skeleton-divider {
|
|
width: 1rpx;
|
|
background: rgba(0, 0, 0, 0.08);
|
|
height: 64rpx;
|
|
align-self: center;
|
|
}
|
|
|
|
/* 会员码骨架 */
|
|
.skeleton-member-code {
|
|
margin: 0 20rpx 20rpx;
|
|
height: 120rpx;
|
|
border-radius: 16rpx;
|
|
background: linear-gradient(90deg, #f0f0f0 25%, #e0e0e0 50%, #f0f0f0 75%);
|
|
background-size: 200% 100%;
|
|
animation: loading 1.5s ease-in-out infinite;
|
|
}
|
|
|
|
/* 功能入口骨架 */
|
|
.skeleton-function-grid {
|
|
background: #FFFFFF;
|
|
margin: 0 20rpx 20rpx;
|
|
border-radius: 16rpx;
|
|
padding: 32rpx 20rpx;
|
|
display: grid;
|
|
grid-template-columns: repeat(4, 1fr);
|
|
gap: 24rpx;
|
|
}
|
|
|
|
.skeleton-function-item {
|
|
display: flex;
|
|
flex-direction: column;
|
|
align-items: center;
|
|
}
|
|
|
|
.skeleton-function-icon {
|
|
width: 88rpx;
|
|
height: 88rpx;
|
|
border-radius: 16rpx;
|
|
background: linear-gradient(90deg, #f0f0f0 25%, #e0e0e0 50%, #f0f0f0 75%);
|
|
background-size: 200% 100%;
|
|
animation: loading 1.5s ease-in-out infinite;
|
|
margin-bottom: 12rpx;
|
|
}
|
|
|
|
.skeleton-function-name {
|
|
width: 80rpx;
|
|
height: 24rpx;
|
|
border-radius: 4rpx;
|
|
background: linear-gradient(90deg, #f0f0f0 25%, #e0e0e0 50%, #f0f0f0 75%);
|
|
background-size: 200% 100%;
|
|
animation: loading 1.5s ease-in-out infinite;
|
|
}
|
|
|
|
/* 菜单列表骨架 */
|
|
.skeleton-menu {
|
|
background: #FFFFFF;
|
|
margin: 0 20rpx;
|
|
border-radius: 16rpx;
|
|
padding: 20rpx 0;
|
|
}
|
|
|
|
.skeleton-menu-item {
|
|
display: flex;
|
|
align-items: center;
|
|
padding: 28rpx 24rpx;
|
|
}
|
|
|
|
.skeleton-menu-icon {
|
|
width: 40rpx;
|
|
height: 40rpx;
|
|
border-radius: 8rpx;
|
|
background: linear-gradient(90deg, #f0f0f0 25%, #e0e0e0 50%, #f0f0f0 75%);
|
|
background-size: 200% 100%;
|
|
animation: loading 1.5s ease-in-out infinite;
|
|
margin-right: 16rpx;
|
|
flex-shrink: 0;
|
|
}
|
|
|
|
.skeleton-menu-text {
|
|
flex: 1;
|
|
height: 28rpx;
|
|
border-radius: 4rpx;
|
|
background: linear-gradient(90deg, #f0f0f0 25%, #e0e0e0 50%, #f0f0f0 75%);
|
|
background-size: 200% 100%;
|
|
animation: loading 1.5s ease-in-out infinite;
|
|
}
|
|
|
|
.skeleton-menu-arrow {
|
|
width: 28rpx;
|
|
height: 28rpx;
|
|
border-radius: 4rpx;
|
|
background: linear-gradient(90deg, #f0f0f0 25%, #e0e0e0 50%, #f0f0f0 75%);
|
|
background-size: 200% 100%;
|
|
animation: loading 1.5s ease-in-out infinite;
|
|
flex-shrink: 0;
|
|
}
|
|
|
|
@keyframes loading {
|
|
0% {
|
|
background-position: 200% 0;
|
|
}
|
|
100% {
|
|
background-position: -200% 0;
|
|
}
|
|
}
|
|
</style>
|