将前端文件从html目录迁移到views目录,按功能模块组织 重构认证中间件和路由处理,简化页面权限控制 更新静态资源引用路径,统一使用/public前缀 添加学生仪表板页面,优化移动端显示 移除旧版html和js文件,更新样式和脚本
194 lines
7.1 KiB
HTML
194 lines
7.1 KiB
HTML
<!DOCTYPE html>
|
||
<html lang="zh-CN">
|
||
<head>
|
||
<meta charset="UTF-8">
|
||
<meta name="viewport" content="width=device-width, initial-scale=1.0">
|
||
<title>摮衣<EFBFBD><EFBFBD>鞟貍蝞∠<EFBFBD>蝟餌<EFBFBD> - 摮衣<E691AE>隞芾”<E88ABE>?/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>
|
||
<!-- 憿園<E686BF>撖潸⏛<E6BDB8>?-->
|
||
<nav class="navbar">
|
||
<div class="navbar-brand">
|
||
<i class="fas fa-graduation-cap"></i>
|
||
<span>XX摮行嵗<EFBFBD>鞟貍蝞∠<EFBFBD>蝟餌<EFBFBD></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>㰘蝸銝?..</span>
|
||
<button id="logoutBtn" class="btn btn-primary">
|
||
<i class="fas fa-sign-out-alt"></i> <20><><EFBFBD>? </button>
|
||
</div>
|
||
</div>
|
||
</nav>
|
||
|
||
<!-- 隞芾”<E88ABE>踹捆<E8B8B9>?-->
|
||
<div class="dashboard-container">
|
||
<!-- 撌虫儒靘扯器<E689AF>?-->
|
||
<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>㰘蝸銝?..</h3>
|
||
<p>摮衣<EFBFBD> | <20>剔漣嚗?span id="studentClass"><3E>㰘蝸銝?..</span></p>
|
||
</div>
|
||
</div>
|
||
</div>
|
||
|
||
<ul class="sidebar-menu">
|
||
<li>
|
||
<a href="#" class="active">
|
||
<i class="fas fa-tachometer-alt"></i>
|
||
<span>隞芾”<EFBFBD>?/span>
|
||
</a>
|
||
</li>
|
||
<li>
|
||
<a href="#">
|
||
<i class="fas fa-chart-bar"></i>
|
||
<span><EFBFBD>鞟貍<EFBFBD>亥砭</span>
|
||
</a>
|
||
</li>
|
||
<li>
|
||
<a href="#">
|
||
<i class="fas fa-book"></i>
|
||
<span>霂曄<EFBFBD>霂行<EFBFBD></span>
|
||
</a>
|
||
</li>
|
||
<li>
|
||
<a href="#">
|
||
<i class="fas fa-user"></i>
|
||
<span>銝芯犖靽⊥<EFBFBD></span>
|
||
</a>
|
||
</li>
|
||
<li>
|
||
<a href="#">
|
||
<i class="fas fa-chart-line"></i>
|
||
<span><EFBFBD>鞟貍<EFBFBD><EFBFBD><EFBFBD></span>
|
||
</a>
|
||
</li>
|
||
<li>
|
||
<a href="#">
|
||
<i class="fas fa-download"></i>
|
||
<span><EFBFBD>鞟貍撖澆枂</span>
|
||
</a>
|
||
</li>
|
||
</ul>
|
||
</aside>
|
||
|
||
<!-- 銝餃<E98A9D>摰孵躹 -->
|
||
<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>
|
||
|
||
<!-- 蝏蠘恣<E8A098>∠<EFBFBD> -->
|
||
<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">撟喳<EFBFBD>蝏拍<EFBFBD></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">撌脖耨霂曄<EFBFBD></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"><EFBFBD>剔漣<EFBFBD>鍦<EFBFBD></div>
|
||
</div>
|
||
</div>
|
||
|
||
<!-- <20>鞟貍銵冽聢 -->
|
||
<div class="grades-table">
|
||
<div class="table-header">
|
||
<h2 class="table-title"><EFBFBD>砍郎<EFBFBD><EFBFBD><EFBFBD>蝏?/h2>
|
||
<div class="table-actions">
|
||
<select class="form-select" style="width: 150px;">
|
||
<option value="all"><EFBFBD><EFBFBD><EFBFBD>匧郎<EFBFBD>?/option>
|
||
<option value="2023-2" selected>2023-2024摮血僑蝚砌<E89D9A>摮行<E691AE></option>
|
||
<option value="2023-1">2023-2024摮血僑蝚砌<E89D9A>摮行<E691AE></option>
|
||
</select>
|
||
<button class="btn btn-primary">
|
||
<i class="fas fa-download"></i> 撖澆枂<E6BE86>鞟貍<E99E9F>? </button>
|
||
</div>
|
||
</div>
|
||
|
||
<div class="table-container">
|
||
<table>
|
||
<thead>
|
||
<tr>
|
||
<th>霂曄<EFBFBD><EFBFBD>滨妍</th>
|
||
<th>霂曄<EFBFBD>隞<EFBFBD><EFBFBD></th>
|
||
<th>摮血<EFBFBD></th>
|
||
<th>撟單𧒄<EFBFBD>鞟貍</th>
|
||
<th><EFBFBD><EFBFBD>錰<EFBFBD>鞟貍</th>
|
||
<th><EFBFBD>餅<EFBFBD>蝏?/th>
|
||
<th>蝏拍<EFBFBD></th>
|
||
<th><EFBFBD>滢<EFBFBD></th>
|
||
</tr>
|
||
</thead>
|
||
<tbody id="gradesTableBody">
|
||
<!-- <20>鞟貍<E99E9F>唳旿撠<E697BF><E692A0>朞<EFBFBD>JavaScript<70>冽<EFBFBD><E586BD><EFBFBD>頧?-->
|
||
</tbody>
|
||
</table>
|
||
</div>
|
||
</div>
|
||
</main>
|
||
</div>
|
||
|
||
<script src="/public/js/student.js"></script>
|
||
<script src="/public/js/auth.js"></script>
|
||
<script>
|
||
// <20>湔鰵敶枏<E695B6><E69E8F>園𡢿
|
||
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>
|