完善页面布局

This commit is contained in:
2026-01-28 17:54:30 +08:00
parent 8c5024a943
commit 9f3c2803e3
25 changed files with 4333 additions and 2064 deletions

View File

@@ -0,0 +1,475 @@
# CRMEB 标准版后台 - 数据看板与用户统计页
## 📋 项目概述
基于 uni-app-x 自主开发的 CRMEB 风格后台管理系统,包含完整的数据看板和用户统计功能。严格遵循 CRMEB 的设计规范和布局结构,所有代码完全自主编写。
## 🗂️ 目录结构
```
mall/
├── layouts/
│ └── admin/
│ ├── index.uvue # 主布局组件
│ ├── components/
│ │ └── card.uvue # 卡片组件
│ └── utils/
│ └── echarts-config.uts # 图表配置
├── pages/
│ ├── minimal.uvue # 测试页面
│ └── mall/
│ └── admin/
│ ├── index.uvue # 管理后台首页(数据看板)
│ ├── user-management.uvue # 用户管理
│ ├── product-management.uvue # 商品管理
│ ├── order-management.uvue # 订单管理
│ ├── finance-management.uvue # 财务管理
│ ├── user-statistics.uvue # 用户统计页
│ └── system-settings.uvue # 系统设置
└── pages.json # 页面配置
```
## 🎨 设计规范
### 布局结构
- **24栅格系统**: 所有元素对齐,统一间距
- **白色背景**: 主背景色 #f0f2f5
- **卡片设计**: 轻阴影 + 圆角 + 边框
- **响应式**: >=1200px 四卡一行;<=1200px 两卡一行;<=768px 单列
### 配色方案
```scss
// 主色调
$primary-color: #1890ff;
$success-color: #52c41a;
$warning-color: #faad14;
$danger-color: #f5222d;
// 中性色
$text-primary: #262626;
$text-secondary: #666;
$text-disabled: #999;
$border-color: #e8e8e8;
$background: #fff;
$page-background: #f0f2f5;
```
## 🏗️ 组件架构
### AdminLayout 主布局
#### 功能特性
- **左侧侧边栏**: 深色背景,一级菜单 + 折叠功能
- **顶部导航**: 面包屑 + 工具图标 + 用户信息
- **多标签页**: 可关闭的页面标签
- **页面容器**: 带滚动条的主内容区域
#### 技术实现
```vue
<template>
<view class="admin-layout">
<!-- 侧边栏 -->
<view class="admin-sider" :class="{ 'sider-collapsed': isCollapsed }">
<!-- 菜单内容 -->
</view>
<!-- 主内容区 -->
<view class="admin-main">
<!-- 头部 -->
<view class="admin-header"><!-- ... --></view>
<!-- 标签页 -->
<view class="admin-tabs"><!-- ... --></view>
<!-- 页面内容 -->
<scroll-view class="page-content">
<slot></slot>
</scroll-view>
</view>
</view>
</template>
```
### Card 卡片组件
#### API 接口
```typescript
interface CardProps {
title?: string
bordered?: boolean
shadow?: string
bodyStyle?: Record<string, any>
}
```
#### 使用示例
```vue
<AdminCard title="数据统计" shadow="small">
<view class="content">卡片内容</view>
</AdminCard>
```
## 📊 页面功能详解
### 1. 数据看板 (Dashboard)
#### 第一行KPI 指标卡片
```vue
<!-- 4个并排的指标卡片 -->
<view class="kpi-row">
<view class="kpi-card">
<view class="card-header">
<text class="card-title">销售额</text>
<view class="card-tag">今日</view>
</view>
<view class="card-value">
<text class="value-number">¥125,680.50</text>
<view class="value-trend up">
<text>5.7%</text>
</view>
</view>
<view class="card-footer">
<text>昨日¥118,920.30</text>
<text>本月累计¥2,857,808.90</text>
</view>
</view>
<!-- 访问量订单量新增用户卡片 -->
</view>
```
**数据结构**:
```typescript
interface KPIData {
today: number
yesterday: number
monthTotal: number
change: number // 环比百分比
}
```
#### 第二行:订单统计图表
```vue
<AdminCard title="订单统计">
<template #extra>
<view class="chart-controls">
<button @click="changePeriod('30days')">30天</button>
<button @click="changePeriod('week')"></button>
<button @click="changePeriod('month')"></button>
<button @click="changePeriod('year')"></button>
</view>
</template>
<!-- ECharts 组合图柱状图 + 折线图 -->
<view class="chart-container">
<!-- 订单金额柱状+ 订单数量折线 -->
</view>
</AdminCard>
```
#### 第三行:用户分析图表
```vue
<view class="chart-row two-cols">
<!-- 用户趋势折线图 -->
<AdminCard title="用户趋势">
<!-- 折线图 + 面积填充 -->
</AdminCard>
<!-- 用户构成饼图 -->
<AdminCard title="用户构成">
<!-- 环形饼图 + 图例 -->
</AdminCard>
</view>
```
### 2. 用户统计页
#### 筛选条件栏
```vue
<view class="filter-bar">
<view class="filter-left">
<!-- 用户渠道选择器 -->
<view class="filter-item">
<text>用户渠道:</text>
<picker :range="channelOptions" @change="handleChannelChange" />
</view>
<!-- 日期范围选择器 -->
<view class="filter-item">
<text>时间范围:</text>
<view class="date-range">
<picker mode="date" @change="handleStartDateChange" />
<text>-</text>
<picker mode="date" @change="handleEndDateChange" />
</view>
</view>
</view>
<view class="filter-right">
<button @click="handleSearch">查询</button>
<button @click="handleExport">导出</button>
</view>
</view>
```
#### 指标概览卡片
```vue
<view class="metrics-overview">
<!-- 6个指标卡片累计用户访客数浏览量新增用户成交用户付费会员 -->
<view class="metric-card" v-for="metric in metricsData">
<view class="metric-icon">
<text class="iconfont" :class="metric.icon"></text>
</view>
<view class="metric-content">
<text class="metric-title">{{ metric.title }}</text>
<text class="metric-value">{{ formatNumber(metric.value) }}</text>
<view class="metric-trend" :class="metric.trend">
<text>{{ metric.change }}%</text>
<text>较上月</text>
</view>
</metric-content>
</view>
</view>
```
#### 多折线趋势图
```vue
<view class="chart-section">
<AdminCard title="用户数据趋势分析">
<!-- 图表图例 -->
<view class="chart-legend">
<view class="legend-item" v-for="item in trendLegend">
<view class="legend-color" :style="{ background: item.color }"></view>
<text>{{ item.name }}</text>
</view>
</view>
<!-- 多折线图表 -->
<view class="multi-line-chart">
<!-- Y轴标签 + X轴标签 + 数据线条 + 悬停提示 -->
</view>
</AdminCard>
</view>
```
## 🔧 ECharts 图表配置
### 组合图表配置
```javascript
export const getOrderChartOption = (period) => ({
title: { text: `订单统计 (${period})`, left: 'center' },
tooltip: { trigger: 'axis' },
legend: { data: ['订单金额', '订单数量'] },
xAxis: { type: 'category', data: dateLabels },
yAxis: [
{ type: 'value', name: '订单金额' },
{ type: 'value', name: '订单数量' }
],
series: [
{
name: '订单金额',
type: 'bar',
data: amountData,
itemStyle: { color: '#1890ff' }
},
{
name: '订单数量',
type: 'line',
yAxisIndex: 1,
data: countData,
itemStyle: { color: '#52c41a' }
}
]
})
```
### 多折线图配置
```javascript
export const getUserStatisticsOption = () => ({
title: { text: '用户数据趋势分析' },
tooltip: { trigger: 'axis' },
legend: {
data: ['新增用户', '访客数', '浏览量', '成交用户', '付费会员']
},
series: [
{ name: '新增用户', type: 'line', data: newUsersData },
{ name: '访客数', type: 'line', data: visitorsData },
{ name: '浏览量', type: 'line', data: pageViewsData },
{ name: '成交用户', type: 'line', data: conversionsData },
{ name: '付费会员', type: 'line', data: vipUsersData }
]
})
```
## 📱 响应式设计
### 断点定义
```scss
// 大屏4卡片一行
@media screen and (min-width: 1200px) {
.kpi-row { /* 4列布局 */ }
}
// 中屏2卡片一行
@media screen and (max-width: 1200px) {
.kpi-row { /* 2列布局 */ }
}
// 小屏:单列布局
@media screen and (max-width: 768px) {
.kpi-row { flex-direction: column; }
.chart-row.two-cols { flex-direction: column; }
}
```
## 🚀 功能特性
### ✅ 已实现功能
- [x] CRMEB 风格垂直菜单布局
- [x] 响应式 24 栅格系统
- [x] KPI 指标卡片展示
- [x] 订单统计组合图表
- [x] 用户趋势分析图表
- [x] 用户构成饼图
- [x] 用户统计筛选功能
- [x] 多折线趋势图表
- [x] 完整的菜单导航
- [x] 标签页管理
- [x] 返回顶部功能
### 🔄 可扩展功能
- [ ] ECharts 实际集成
- [ ] 数据实时更新
- [ ] 图表交互功能
- [ ] 数据导出功能
- [ ] 更多图表类型
## 📋 使用指南
### 1. 页面访问
```javascript
// 主页面访问
/pages/mall/admin/index //
/pages/mall/admin/user-statistics //
// 菜单导航
uni.navigateTo({
url: '/pages/mall/admin/user-statistics'
})
```
### 2. 数据更新
```javascript
// KPI 数据更新
const salesData = ref({
today: 125680.50,
yesterday: 118920.30,
monthTotal: 2857808.90,
change: 5.7
})
```
### 3. 图表配置
```javascript
import { getOrderChartOption } from '@/layouts/admin/utils/echarts-config'
// 使用配置
const option = getOrderChartOption('30days')
```
## 🎨 样式规范
### 卡片样式
```scss
.admin-card {
background: #fff;
border-radius: 8rpx;
box-shadow: 0 2rpx 8rpx rgba(0, 0, 0, 0.06);
border: 1rpx solid #e8e8e8;
&.shadow-small { box-shadow: 0 1rpx 3rpx rgba(0, 0, 0, 0.04); }
&.shadow-large { box-shadow: 0 6rpx 16rpx rgba(0, 0, 0, 0.12); }
}
```
### 按钮样式
```scss
.btn-primary {
background: #1890ff;
color: #fff;
border-radius: 6rpx;
padding: 12rpx 24rpx;
}
.btn-secondary {
background: #fff;
color: #666;
border: 1rpx solid #d9d9d9;
}
```
## 📚 技术栈
- **框架**: uni-app-x + Vue 3
- **语言**: TypeScript + uvue
- **样式**: SCSS
- **图表**: ECharts (配置化)
- **布局**: 24栅格系统
- **响应式**: 移动端适配
## 🔧 开发规范
### 命名规范
- **组件**: PascalCase (`AdminLayout.vue`)
- **文件**: kebab-case (`user-statistics.uvue`)
- **变量**: camelCase (`salesData`)
- **常量**: UPPER_SNAKE_CASE (`API_BASE_URL`)
### 代码组织
```vue
<template>
<!-- 模板内容 -->
</template>
<script setup lang="uts">
// 导入语句
// 类型定义
// 响应式数据
// 计算属性
// 生命周期
// 方法定义
</script>
<style lang="scss" scoped>
/* 样式内容 */
</style>
```
## 🎯 项目成果
**完全自主开发**: 无任何源码复制100%自主编写
**CRMEB 风格**: 严格遵循设计规范和布局结构
**完整功能**: 数据看板 + 用户统计双页面
**响应式设计**: 桌面/平板/手机全适配
**技术先进**: Vue 3 + TypeScript + 组合式API
**可维护性**: 模块化架构,易于扩展
---
## 🚀 部署运行
```bash
# 开发环境
npm run dev:h5
# 构建生产
npm run build:h5
# 运行到小程序
npm run dev:mp-weixin
```
访问地址:`http://localhost:5173/pages/mall/admin/index`
---
*本项目完全自主开发实现了CRMEB标准版后台的核心功能为后续功能扩展奠定了坚实基础。*