refactor(frontend): 移除未使用的CSS和HTML文件
清理前端项目中未使用的CSS样式文件和HTML模板文件,包括notification.css、main.css、style.css和auth/index.html
This commit is contained in:
@@ -1,215 +0,0 @@
|
|||||||
/* 首页通用交互样式 */
|
|
||||||
|
|
||||||
/* 滚动时导航栏样式 */
|
|
||||||
.navbar-scrolled {
|
|
||||||
background-color: rgba(255, 255, 255, 0.95) !important;
|
|
||||||
box-shadow: 0 2px 10px rgba(0, 0, 0, 0.1);
|
|
||||||
backdrop-filter: blur(10px);
|
|
||||||
}
|
|
||||||
|
|
||||||
.navbar-scrolled .navbar-brand,
|
|
||||||
.navbar-scrolled .nav-link {
|
|
||||||
color: #333 !important;
|
|
||||||
}
|
|
||||||
|
|
||||||
.navbar-scrolled .navbar-toggler-icon {
|
|
||||||
background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 30 30'%3e%3cpath stroke='rgba(0, 0, 0, 0.7)' stroke-linecap='round' stroke-miterlimit='10' stroke-width='2' d='M4 7h22M4 15h22M4 23h22'/%3e%3c/svg%3e") !important;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* 滚动动画效果 */
|
|
||||||
.feature-card, .hero-content {
|
|
||||||
opacity: 0;
|
|
||||||
transform: translateY(20px);
|
|
||||||
transition: opacity 0.6s ease, transform 0.6s ease;
|
|
||||||
}
|
|
||||||
|
|
||||||
.feature-card.animate-in,
|
|
||||||
.hero-content.animate-in {
|
|
||||||
opacity: 1;
|
|
||||||
transform: translateY(0);
|
|
||||||
}
|
|
||||||
|
|
||||||
/* 返回顶部按钮 */
|
|
||||||
#backToTop {
|
|
||||||
position: fixed;
|
|
||||||
bottom: 30px;
|
|
||||||
right: 30px;
|
|
||||||
width: 50px;
|
|
||||||
height: 50px;
|
|
||||||
background-color: #4e73df;
|
|
||||||
color: white;
|
|
||||||
border: none;
|
|
||||||
border-radius: 50%;
|
|
||||||
cursor: pointer;
|
|
||||||
opacity: 0;
|
|
||||||
visibility: hidden;
|
|
||||||
transition: all 0.3s ease;
|
|
||||||
z-index: 1000;
|
|
||||||
display: flex;
|
|
||||||
align-items: center;
|
|
||||||
justify-content: center;
|
|
||||||
font-size: 1.2rem;
|
|
||||||
box-shadow: 0 4px 15px rgba(78, 115, 223, 0.3);
|
|
||||||
}
|
|
||||||
|
|
||||||
#backToTop:hover {
|
|
||||||
background-color: #2e59d9;
|
|
||||||
transform: translateY(-3px);
|
|
||||||
box-shadow: 0 6px 20px rgba(78, 115, 223, 0.4);
|
|
||||||
}
|
|
||||||
|
|
||||||
#backToTop.show {
|
|
||||||
opacity: 1;
|
|
||||||
visibility: visible;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* 通知样式 */
|
|
||||||
.notification {
|
|
||||||
position: fixed;
|
|
||||||
top: 20px;
|
|
||||||
right: 20px;
|
|
||||||
padding: 15px 20px;
|
|
||||||
border-radius: 8px;
|
|
||||||
background-color: white;
|
|
||||||
box-shadow: 0 4px 15px rgba(0, 0, 0, 0.1);
|
|
||||||
z-index: 9999;
|
|
||||||
opacity: 0;
|
|
||||||
transform: translateX(100%);
|
|
||||||
transition: opacity 0.3s ease, transform 0.3s ease;
|
|
||||||
max-width: 350px;
|
|
||||||
display: flex;
|
|
||||||
align-items: center;
|
|
||||||
}
|
|
||||||
|
|
||||||
.notification.show {
|
|
||||||
opacity: 1;
|
|
||||||
transform: translateX(0);
|
|
||||||
}
|
|
||||||
|
|
||||||
.notification-content {
|
|
||||||
display: flex;
|
|
||||||
align-items: center;
|
|
||||||
gap: 10px;
|
|
||||||
}
|
|
||||||
|
|
||||||
.notification i {
|
|
||||||
font-size: 1.2rem;
|
|
||||||
}
|
|
||||||
|
|
||||||
.notification-success {
|
|
||||||
border-left: 4px solid #1cc88a;
|
|
||||||
}
|
|
||||||
|
|
||||||
.notification-success i {
|
|
||||||
color: #1cc88a;
|
|
||||||
}
|
|
||||||
|
|
||||||
.notification-error {
|
|
||||||
border-left: 4px solid #e74a3b;
|
|
||||||
}
|
|
||||||
|
|
||||||
.notification-error i {
|
|
||||||
color: #e74a3b;
|
|
||||||
}
|
|
||||||
|
|
||||||
.notification-info {
|
|
||||||
border-left: 4px solid #36b9cc;
|
|
||||||
}
|
|
||||||
|
|
||||||
.notification-info i {
|
|
||||||
color: #36b9cc;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* 移动端菜单优化 */
|
|
||||||
@media (max-width: 991.98px) {
|
|
||||||
.navbar-collapse {
|
|
||||||
background-color: white;
|
|
||||||
padding: 20px;
|
|
||||||
border-radius: 8px;
|
|
||||||
box-shadow: 0 4px 15px rgba(0, 0, 0, 0.1);
|
|
||||||
margin-top: 10px;
|
|
||||||
}
|
|
||||||
|
|
||||||
.navbar-nav .nav-link {
|
|
||||||
padding: 10px 15px;
|
|
||||||
border-radius: 4px;
|
|
||||||
margin-bottom: 5px;
|
|
||||||
}
|
|
||||||
|
|
||||||
.navbar-nav .nav-link:hover {
|
|
||||||
background-color: #f8f9fc;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/* 平滑滚动优化 */
|
|
||||||
html {
|
|
||||||
scroll-behavior: smooth;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* 当前页面高亮 */
|
|
||||||
.nav-link.active {
|
|
||||||
color: #4e73df !important;
|
|
||||||
font-weight: 600;
|
|
||||||
}
|
|
||||||
|
|
||||||
.nav-link.active::after {
|
|
||||||
content: '';
|
|
||||||
position: absolute;
|
|
||||||
bottom: -2px;
|
|
||||||
left: 0;
|
|
||||||
width: 100%;
|
|
||||||
height: 2px;
|
|
||||||
background-color: #4e73df;
|
|
||||||
border-radius: 2px;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* 按钮悬停效果增强 */
|
|
||||||
.btn {
|
|
||||||
transition: all 0.3s ease;
|
|
||||||
}
|
|
||||||
|
|
||||||
.btn:hover {
|
|
||||||
transform: translateY(-2px);
|
|
||||||
box-shadow: 0 4px 15px rgba(0, 0, 0, 0.1);
|
|
||||||
}
|
|
||||||
|
|
||||||
/* 卡片悬停效果 */
|
|
||||||
.feature-card {
|
|
||||||
transition: all 0.3s ease;
|
|
||||||
}
|
|
||||||
|
|
||||||
.feature-card:hover {
|
|
||||||
transform: translateY(-5px);
|
|
||||||
box-shadow: 0 8px 25px rgba(0, 0, 0, 0.1);
|
|
||||||
}
|
|
||||||
|
|
||||||
/* 加载动画 */
|
|
||||||
.loading-spinner {
|
|
||||||
display: inline-block;
|
|
||||||
width: 20px;
|
|
||||||
height: 20px;
|
|
||||||
border: 3px solid rgba(255, 255, 255, 0.3);
|
|
||||||
border-radius: 50%;
|
|
||||||
border-top-color: white;
|
|
||||||
animation: spin 1s ease-in-out infinite;
|
|
||||||
}
|
|
||||||
|
|
||||||
@keyframes spin {
|
|
||||||
to { transform: rotate(360deg); }
|
|
||||||
}
|
|
||||||
|
|
||||||
/* 响应式调整 */
|
|
||||||
@media (max-width: 768px) {
|
|
||||||
#backToTop {
|
|
||||||
bottom: 20px;
|
|
||||||
right: 20px;
|
|
||||||
width: 45px;
|
|
||||||
height: 45px;
|
|
||||||
}
|
|
||||||
|
|
||||||
.notification {
|
|
||||||
left: 20px;
|
|
||||||
right: 20px;
|
|
||||||
max-width: none;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
@@ -1,47 +0,0 @@
|
|||||||
/* 通知消息样式 */
|
|
||||||
.notification {
|
|
||||||
position: fixed;
|
|
||||||
top: 20px;
|
|
||||||
right: 20px;
|
|
||||||
padding: 15px 25px;
|
|
||||||
background: white;
|
|
||||||
border-radius: 8px;
|
|
||||||
box-shadow: 0 4px 12px rgba(0,0,0,0.15);
|
|
||||||
display: flex;
|
|
||||||
align-items: center;
|
|
||||||
z-index: 1000;
|
|
||||||
transform: translateX(120%);
|
|
||||||
transition: transform 0.3s ease;
|
|
||||||
border-left: 4px solid #4e73df;
|
|
||||||
max-width: 350px;
|
|
||||||
}
|
|
||||||
|
|
||||||
.notification.show {
|
|
||||||
transform: translateX(0);
|
|
||||||
}
|
|
||||||
|
|
||||||
.notification.success {
|
|
||||||
border-left-color: #2ecc71;
|
|
||||||
}
|
|
||||||
|
|
||||||
.notification.error {
|
|
||||||
border-left-color: #e74c3c;
|
|
||||||
}
|
|
||||||
|
|
||||||
.notification i {
|
|
||||||
margin-right: 10px;
|
|
||||||
font-size: 1.2em;
|
|
||||||
}
|
|
||||||
|
|
||||||
.notification.success i {
|
|
||||||
color: #2ecc71;
|
|
||||||
}
|
|
||||||
|
|
||||||
.notification.error i {
|
|
||||||
color: #e74c3c;
|
|
||||||
}
|
|
||||||
|
|
||||||
.notification-content {
|
|
||||||
font-size: 14px;
|
|
||||||
color: #333;
|
|
||||||
}
|
|
||||||
File diff suppressed because it is too large
Load Diff
@@ -1,213 +0,0 @@
|
|||||||
// 首页通用JavaScript功能
|
|
||||||
// 主要处理导航栏交互、页面滚动效果等通用功能
|
|
||||||
|
|
||||||
class MainPage {
|
|
||||||
constructor() {
|
|
||||||
this.init();
|
|
||||||
}
|
|
||||||
|
|
||||||
init() {
|
|
||||||
// 初始化所有功<E69C89><E58A9F>? this.initNavbar();
|
|
||||||
this.initScrollEffects();
|
|
||||||
this.initSmoothScroll();
|
|
||||||
this.initBackToTop();
|
|
||||||
this.initMobileMenu();
|
|
||||||
this.initAuthButtons();
|
|
||||||
}
|
|
||||||
|
|
||||||
// 初始化导航栏交互
|
|
||||||
initNavbar() {
|
|
||||||
const navbar = document.querySelector('.navbar');
|
|
||||||
if (!navbar) return;
|
|
||||||
|
|
||||||
// 滚动时改变导航栏样式
|
|
||||||
window.addEventListener('scroll', () => {
|
|
||||||
if (window.scrollY > 50) {
|
|
||||||
navbar.classList.add('navbar-scrolled');
|
|
||||||
} else {
|
|
||||||
navbar.classList.remove('navbar-scrolled');
|
|
||||||
}
|
|
||||||
});
|
|
||||||
|
|
||||||
// 初始化当前页面高<E99DA2><E9AB98>? this.highlightCurrentPage();
|
|
||||||
}
|
|
||||||
|
|
||||||
// 高亮当前页面导航链接
|
|
||||||
highlightCurrentPage() {
|
|
||||||
const currentPath = window.location.pathname;
|
|
||||||
const navLinks = document.querySelectorAll('.nav-link');
|
|
||||||
|
|
||||||
navLinks.forEach(link => {
|
|
||||||
const href = link.getAttribute('href');
|
|
||||||
if (href && currentPath.includes(href.replace('.html', ''))) {
|
|
||||||
link.classList.add('active');
|
|
||||||
}
|
|
||||||
});
|
|
||||||
}
|
|
||||||
|
|
||||||
// 初始化滚动效<E58AA8><E69588>? initScrollEffects() {
|
|
||||||
// 滚动时显<E697B6><E698BE>?隐藏元素
|
|
||||||
const observerOptions = {
|
|
||||||
root: null,
|
|
||||||
rootMargin: '0px',
|
|
||||||
threshold: 0.1
|
|
||||||
};
|
|
||||||
|
|
||||||
const observer = new IntersectionObserver((entries) => {
|
|
||||||
entries.forEach(entry => {
|
|
||||||
if (entry.isIntersecting) {
|
|
||||||
entry.target.classList.add('animate-in');
|
|
||||||
}
|
|
||||||
});
|
|
||||||
}, observerOptions);
|
|
||||||
|
|
||||||
// 观察需要动画的元素
|
|
||||||
document.querySelectorAll('.feature-card, .hero-content').forEach(el => {
|
|
||||||
observer.observe(el);
|
|
||||||
});
|
|
||||||
}
|
|
||||||
|
|
||||||
// 初始化平滑滚<E6BB91><E6BB9A>? initSmoothScroll() {
|
|
||||||
document.querySelectorAll('a[href^="#"]').forEach(anchor => {
|
|
||||||
anchor.addEventListener('click', (e) => {
|
|
||||||
e.preventDefault();
|
|
||||||
const targetId = anchor.getAttribute('href');
|
|
||||||
if (targetId === '#') return;
|
|
||||||
|
|
||||||
const targetElement = document.querySelector(targetId);
|
|
||||||
if (targetElement) {
|
|
||||||
targetElement.scrollIntoView({
|
|
||||||
behavior: 'smooth',
|
|
||||||
block: 'start'
|
|
||||||
});
|
|
||||||
}
|
|
||||||
});
|
|
||||||
});
|
|
||||||
}
|
|
||||||
|
|
||||||
// 初始化返回顶部按<E983A8><E68C89>? initBackToTop() {
|
|
||||||
const backToTopBtn = document.createElement('button');
|
|
||||||
backToTopBtn.id = 'backToTop';
|
|
||||||
backToTopBtn.innerHTML = '<i class="fas fa-chevron-up"></i>';
|
|
||||||
backToTopBtn.title = '返回顶部';
|
|
||||||
document.body.appendChild(backToTopBtn);
|
|
||||||
|
|
||||||
// 滚动时显<E697B6><E698BE>?隐藏按钮
|
|
||||||
window.addEventListener('scroll', () => {
|
|
||||||
if (window.scrollY > 300) {
|
|
||||||
backToTopBtn.classList.add('show');
|
|
||||||
} else {
|
|
||||||
backToTopBtn.classList.remove('show');
|
|
||||||
}
|
|
||||||
});
|
|
||||||
|
|
||||||
// 点击返回顶部
|
|
||||||
backToTopBtn.addEventListener('click', () => {
|
|
||||||
window.scrollTo({
|
|
||||||
top: 0,
|
|
||||||
behavior: 'smooth'
|
|
||||||
});
|
|
||||||
});
|
|
||||||
}
|
|
||||||
|
|
||||||
// 初始化移动端菜单
|
|
||||||
initMobileMenu() {
|
|
||||||
const navbarToggler = document.querySelector('.navbar-toggler');
|
|
||||||
const navbarCollapse = document.querySelector('.navbar-collapse');
|
|
||||||
|
|
||||||
if (!navbarToggler || !navbarCollapse) return;
|
|
||||||
|
|
||||||
navbarToggler.addEventListener('click', () => {
|
|
||||||
navbarCollapse.classList.toggle('show');
|
|
||||||
});
|
|
||||||
|
|
||||||
// 点击菜单项后自动关闭移动菜单
|
|
||||||
document.querySelectorAll('.navbar-nav .nav-link').forEach(link => {
|
|
||||||
link.addEventListener('click', () => {
|
|
||||||
if (navbarCollapse.classList.contains('show')) {
|
|
||||||
navbarCollapse.classList.remove('show');
|
|
||||||
}
|
|
||||||
});
|
|
||||||
});
|
|
||||||
}
|
|
||||||
|
|
||||||
// 初始化认证按钮状<E992AE><E78AB6>? initAuthButtons() {
|
|
||||||
// 检查用户是否已登录
|
|
||||||
this.checkLoginStatus().then(user => {
|
|
||||||
const loginBtn = document.getElementById('loginBtn');
|
|
||||||
const registerBtn = document.getElementById('registerBtn');
|
|
||||||
const heroLoginBtn = document.getElementById('heroLoginBtn');
|
|
||||||
|
|
||||||
if (user) {
|
|
||||||
// 用户已登录,显示仪表板按<E69DBF><E68C89>? // 根据用户角色设置正确的仪表板路径
|
|
||||||
let dashboardUrl = '/dashboard';
|
|
||||||
if (user.role === 'student') {
|
|
||||||
dashboardUrl = '/student/dashboard';
|
|
||||||
} else if (user.role === 'teacher') {
|
|
||||||
dashboardUrl = '/teacher/dashboard';
|
|
||||||
} else if (user.role === 'admin') {
|
|
||||||
dashboardUrl = '/admin/dashboard';
|
|
||||||
}
|
|
||||||
|
|
||||||
if (loginBtn) {
|
|
||||||
loginBtn.textContent = '进入仪表<E4BBAA><E8A1A8>?;
|
|
||||||
loginBtn.href = dashboardUrl;
|
|
||||||
}
|
|
||||||
if (heroLoginBtn) {
|
|
||||||
heroLoginBtn.textContent = '进入仪表<EFBFBD><EFBFBD>?;
|
|
||||||
heroLoginBtn.href = dashboardUrl;
|
|
||||||
}
|
|
||||||
if (registerBtn) {
|
|
||||||
registerBtn.style.display = 'none';
|
|
||||||
}
|
|
||||||
}
|
|
||||||
});
|
|
||||||
}
|
|
||||||
|
|
||||||
// 检查登录状<E5BD95><E78AB6>? async checkLoginStatus() {
|
|
||||||
try {
|
|
||||||
const apiBase = window.location.protocol === 'file:' ? 'http://localhost:3000/api' : '/api';
|
|
||||||
const response = await fetch(`${apiBase}/auth/me`);
|
|
||||||
const data = await response.json();
|
|
||||||
return data.success && data.user;
|
|
||||||
} catch (error) {
|
|
||||||
console.log('用户未登<E69CAA><E799BB>?);
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// 显示通知
|
|
||||||
showNotification(message, type = 'info') {
|
|
||||||
// 创建通知元素
|
|
||||||
const notification = document.createElement('div');
|
|
||||||
notification.className = `notification notification-${type}`;
|
|
||||||
notification.innerHTML = `
|
|
||||||
<div class="notification-content">
|
|
||||||
<i class="fas ${type === 'success' ? 'fa-check-circle' : type === 'error' ? 'fa-exclamation-circle' : 'fa-info-circle'}"></i>
|
|
||||||
<span>${message}</span>
|
|
||||||
</div>
|
|
||||||
`;
|
|
||||||
|
|
||||||
// 添加到页<E588B0><E9A1B5>? document.body.appendChild(notification);
|
|
||||||
|
|
||||||
// 显示通知
|
|
||||||
setTimeout(() => {
|
|
||||||
notification.classList.add('show');
|
|
||||||
}, 10);
|
|
||||||
|
|
||||||
// 自动隐藏
|
|
||||||
setTimeout(() => {
|
|
||||||
notification.classList.remove('show');
|
|
||||||
setTimeout(() => {
|
|
||||||
if (notification.parentNode) {
|
|
||||||
notification.parentNode.removeChild(notification);
|
|
||||||
}
|
|
||||||
}, 300);
|
|
||||||
}, 3000);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// 页面加载完成后初始化
|
|
||||||
document.addEventListener('DOMContentLoaded', () => {
|
|
||||||
new MainPage();
|
|
||||||
});
|
|
||||||
@@ -1,130 +0,0 @@
|
|||||||
<!DOCTYPE html>
|
|
||||||
<html lang="zh-CN">
|
|
||||||
<head>
|
|
||||||
<meta charset="UTF-8">
|
|
||||||
<meta name="viewport" content="width=device-width, initial-scale=1.0">
|
|
||||||
<title>学生成绩管理系统</title>
|
|
||||||
<link rel="stylesheet" href="/public/css/style.css">
|
|
||||||
<link rel="stylesheet" href="/public/css/main.css">
|
|
||||||
</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">
|
|
||||||
<a href="/login" class="btn btn-primary" id="loginBtn">
|
|
||||||
<i class="fas fa-sign-in-alt"></i> 登录
|
|
||||||
</a>
|
|
||||||
<a href="/register" class="btn btn-secondary" id="registerBtn">
|
|
||||||
<i class="fas fa-user-plus"></i> 注册
|
|
||||||
</a>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
</nav>
|
|
||||||
|
|
||||||
<!-- 主体内容<E58685><E5AEB9>?-->
|
|
||||||
<main>
|
|
||||||
<!-- 英雄区域 -->
|
|
||||||
<section class="hero-section">
|
|
||||||
<div class="hero-content">
|
|
||||||
<h1 class="hero-title">XX学校学生成绩管理系统</h1>
|
|
||||||
<p class="hero-subtitle">
|
|
||||||
高效、安全、智能的成绩管理平台,为学校师生提供全方位的成绩管理服务<E69C8D><E58AA1>? 实现成绩录入、查询、统计和分析的一体化解决方案<E696B9><E6A188>? </p>
|
|
||||||
<div class="cta-buttons">
|
|
||||||
<a href="/login" class="btn btn-primary" id="heroLoginBtn">
|
|
||||||
<i class="fas fa-sign-in-alt"></i> 立即登录
|
|
||||||
</a>
|
|
||||||
<a href="#features" class="btn btn-secondary">
|
|
||||||
<i class="fas fa-info-circle"></i> 了解功能
|
|
||||||
</a>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
</section>
|
|
||||||
|
|
||||||
<!-- 功能特色 -->
|
|
||||||
<section id="features" class="features-section">
|
|
||||||
<h2 class="section-title">系统功能特色</h2>
|
|
||||||
<div class="features-grid">
|
|
||||||
<div class="feature-card">
|
|
||||||
<div class="feature-icon">
|
|
||||||
<i class="fas fa-user-graduate"></i>
|
|
||||||
</div>
|
|
||||||
<h3 class="feature-title">学生成绩查询</h3>
|
|
||||||
<p class="feature-description">
|
|
||||||
学生可随时查看个人成绩,包括各科成绩、平均分、排名等信息<E4BFA1><E681AF>? 支持成绩趋势分析和历史记录查看<E69FA5><E79C8B>? </p>
|
|
||||||
</div>
|
|
||||||
|
|
||||||
<div class="feature-card">
|
|
||||||
<div class="feature-icon">
|
|
||||||
<i class="fas fa-chalkboard-teacher"></i>
|
|
||||||
</div>
|
|
||||||
<h3 class="feature-title">教师成绩管理</h3>
|
|
||||||
<p class="feature-description">
|
|
||||||
教师可便捷录入、修改、查询学生成绩,支持批量操作和成绩统计分析,
|
|
||||||
提供多种数据导出格式<E6A0BC><E5BC8F>? </p>
|
|
||||||
</div>
|
|
||||||
|
|
||||||
<div class="feature-card">
|
|
||||||
<div class="feature-icon">
|
|
||||||
<i class="fas fa-user-shield"></i>
|
|
||||||
</div>
|
|
||||||
<h3 class="feature-title">管理员权限控<EFBFBD><EFBFBD>?/h3>
|
|
||||||
<p class="feature-description">
|
|
||||||
管理员可管理用户账户、学生信息,查看系统统计报表<E68AA5><E8A1A8>? 设置权限和系统参数,确保数据安全<E5AE89><E585A8>? </p>
|
|
||||||
</div>
|
|
||||||
|
|
||||||
<div class="feature-card">
|
|
||||||
<div class="feature-icon">
|
|
||||||
<i class="fas fa-chart-line"></i>
|
|
||||||
</div>
|
|
||||||
<h3 class="feature-title">智能统计分析</h3>
|
|
||||||
<p class="feature-description">
|
|
||||||
提供丰富的图表统计功能,包括成绩分布、趋势分析、对比图表等<E8A1A8><E7AD89>? 帮助学校进行教学评估和决策支持<E694AF><E68C81>? </p>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
</section>
|
|
||||||
|
|
||||||
<!-- 行动号召 -->
|
|
||||||
<section class="cta-section">
|
|
||||||
<h2 class="cta-title">立即体验智能成绩管理</h2>
|
|
||||||
<p style="font-size: 1.2rem; color: #666; margin-bottom: 40px; max-width: 600px; margin-left: auto; margin-right: auto;">
|
|
||||||
加入XX学校成绩管理系统,体验高效、便捷的成绩管理服务<E69C8D><E58AA1>? </p>
|
|
||||||
<div class="cta-buttons">
|
|
||||||
<a href="/login" class="btn btn-primary">
|
|
||||||
<i class="fas fa-sign-in-alt"></i> 开始使<E5A78B><E4BDBF>? </a>
|
|
||||||
<a href="#" class="btn btn-secondary">
|
|
||||||
<i class="fas fa-book"></i> 查看文档
|
|
||||||
</a>
|
|
||||||
</div>
|
|
||||||
</section>
|
|
||||||
</main>
|
|
||||||
|
|
||||||
<!-- 页脚 -->
|
|
||||||
<footer class="footer">
|
|
||||||
<div class="footer-content">
|
|
||||||
<h3 style="margin-bottom: 20px;">XX学校学生成绩管理系统</h3>
|
|
||||||
<p style="color: #ccc; margin-bottom: 20px; max-width: 600px; margin-left: auto; margin-right: auto;">
|
|
||||||
致力于为学校提供专业、安全、高效的数字化成绩管理解决方案<E696B9><E6A188>? </p>
|
|
||||||
<div class="footer-links">
|
|
||||||
<a href="#"><i class="fas fa-info-circle"></i> 关于我们</a>
|
|
||||||
<a href="#"><i class="fas fa-envelope"></i> 联系我们</a>
|
|
||||||
<a href="#"><i class="fas fa-shield-alt"></i> 隐私政策</a>
|
|
||||||
<a href="#"><i class="fas fa-file-contract"></i> 服务条款</a>
|
|
||||||
</div>
|
|
||||||
<div class="copyright">
|
|
||||||
<p>© 2023 XX学校学生成绩管理系统 版权所<E69D83><E68980>?/p>
|
|
||||||
<p>联系电话<EFBFBD><EFBFBD>?10-12345678 | 邮箱:contact@school.edu.cn</p>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
</footer>
|
|
||||||
|
|
||||||
<script src="/public/js/main.js"></script>
|
|
||||||
</body>
|
|
||||||
</html>
|
|
||||||
@@ -1,5 +1,4 @@
|
|||||||
@echo off
|
@echo off
|
||||||
:: 使用简单的语法避免编码引起的解析错误
|
|
||||||
cd /d %~dp0
|
cd /d %~dp0
|
||||||
cd ..\backend
|
cd ..\backend
|
||||||
|
|
||||||
|
|||||||
Reference in New Issue
Block a user