refactor(frontend): 重构前端目录结构并优化认证流程

将前端文件从html目录迁移到views目录,按功能模块组织
重构认证中间件和路由处理,简化页面权限控制
更新静态资源引用路径,统一使用/public前缀
添加学生仪表板页面,优化移动端显示
移除旧版html和js文件,更新样式和脚本
This commit is contained in:
祀梦
2025-12-21 22:07:23 +08:00
parent 38b200f9b3
commit bcf2c71fad
20 changed files with 2009 additions and 2009 deletions

View File

@@ -0,0 +1,193 @@
<!DOCTYPE html>
<html lang="zh-CN">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>学生成绩管理系统 - 学生仪表<E4BBAA><E8A1A8>?/title>
<link rel="stylesheet" href="/public/css/style.css">
<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/6.0.0/css/all.min.css">
</head>
</head>
<body>
<!-- 顶部导航<E5AFBC><E888AA>?-->
<nav class="navbar">
<div class="navbar-brand">
<i class="fas fa-graduation-cap"></i>
<span>XX学校成绩管理系统</span>
</div>
<div class="navbar-menu">
<a href="/" class="btn btn-secondary">
<i class="fas fa-home"></i> 主页
</a>
<div class="navbar-user">
<span class="user-name" id="userName">加载<EFBFBD><EFBFBD>?..</span>
<button id="logoutBtn" class="btn btn-primary">
<i class="fas fa-sign-out-alt"></i> 退<><E98080>? </button>
</div>
</div>
</nav>
<!-- 仪表板容<E69DBF><E5AEB9>?-->
<div class="dashboard-container">
<!-- 左侧侧边<E4BEA7><E8BEB9>?-->
<aside class="sidebar">
<div class="sidebar-header">
<div class="user-info">
<div class="user-avatar">
<i class="fas fa-user-graduate"></i>
</div>
<div class="user-details">
<h3 id="studentName">加载<EFBFBD><EFBFBD>?..</h3>
<p>学生 | 班级<E78FAD><E7BAA7>?span id="studentClass">加载<E58AA0><E8BDBD>?..</span></p>
</div>
</div>
</div>
<ul class="sidebar-menu">
<li>
<a href="#" class="active">
<i class="fas fa-tachometer-alt"></i>
<span>仪表<EFBFBD><EFBFBD>?/span>
</a>
</li>
<li>
<a href="#">
<i class="fas fa-chart-bar"></i>
<span>成绩查询</span>
</a>
</li>
<li>
<a href="#">
<i class="fas fa-book"></i>
<span>课程详情</span>
</a>
</li>
<li>
<a href="#">
<i class="fas fa-user"></i>
<span>个人信息</span>
</a>
</li>
<li>
<a href="#">
<i class="fas fa-chart-line"></i>
<span>成绩分析</span>
</a>
</li>
<li>
<a href="#">
<i class="fas fa-download"></i>
<span>成绩导出</span>
</a>
</li>
</ul>
</aside>
<!-- 主内容区 -->
<main class="main-content">
<div class="content-header">
<div>
<h1 class="page-title">学生仪表<EFBFBD><EFBFBD>?/h1>
<div class="breadcrumb">
<a href="/">主页</a>
<i class="fas fa-chevron-right"></i>
<span>学生仪表<EFBFBD><EFBFBD>?/span>
</div>
</div>
<div class="current-time" id="currentTime"></div>
</div>
<!-- 统计卡片 -->
<div class="stats-grid">
<div class="stat-card">
<div class="stat-icon gpa">
<i class="fas fa-star"></i>
</div>
<div class="stat-value" id="gpaValue">3.75</div>
<div class="stat-label">平均绩点</div>
</div>
<div class="stat-card">
<div class="stat-icon courses">
<i class="fas fa-book"></i>
</div>
<div class="stat-value" id="courseCount">8</div>
<div class="stat-label">已修课程</div>
</div>
<div class="stat-card">
<div class="stat-icon credits">
<i class="fas fa-certificate"></i>
</div>
<div class="stat-value" id="creditTotal">24</div>
<div class="stat-label">总学<EFBFBD><EFBFBD>?/div>
</div>
<div class="stat-card">
<div class="stat-icon ranking">
<i class="fas fa-trophy"></i>
</div>
<div class="stat-value" id="classRank">5</div>
<div class="stat-label">班级排名</div>
</div>
</div>
<!-- 成绩表格 -->
<div class="grades-table">
<div class="table-header">
<h2 class="table-title">本学期成<EFBFBD><EFBFBD>?/h2>
<div class="table-actions">
<select class="form-select" style="width: 150px;">
<option value="all">所有学<EFBFBD><EFBFBD>?/option>
<option value="2023-2" selected>2023-2024学年第二学期</option>
<option value="2023-1">2023-2024学年第一学期</option>
</select>
<button class="btn btn-primary">
<i class="fas fa-download"></i> 导出成绩<E68890><E7BBA9>? </button>
</div>
</div>
<div class="table-container">
<table>
<thead>
<tr>
<th>课程名称</th>
<th>课程代码</th>
<th>学分</th>
<th>平时成绩</th>
<th>期末成绩</th>
<th>总成<EFBFBD><EFBFBD>?/th>
<th>绩点</th>
<th>操作</th>
</tr>
</thead>
<tbody id="gradesTableBody">
<!-- 成绩数据将通过JavaScript动态加<E68081><E58AA0>?-->
</tbody>
</table>
</div>
</div>
</main>
</div>
<script src="/public/js/student.js"></script>
<script src="/public/js/auth.js"></script>
<script>
// 更新当前时间
function updateCurrentTime() {
const now = new Date();
const options = {
year: 'numeric',
month: 'long',
day: 'numeric',
hour: '2-digit',
minute: '2-digit',
second: '2-digit'
};
document.getElementById('currentTime').textContent = now.toLocaleString('zh-CN', options);
}
setInterval(updateCurrentTime, 1000);
updateCurrentTime();
</script>
</body>
</html>