Files
vpUni/.svn/pristine/8b/8b54964305674eae436da5b140d9382899164f4d.svn-base
2026-03-09 16:39:03 +08:00

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>