vue3实现教务教育教学管理系统后台ui原型图代码
代码语言:html
所属分类:布局界面
代码描述:vue3实现教务教育教学管理系统后台ui原型图代码
代码标签: vue 教务 教育 教学 管理 系统 后台 ui 原型图 代码
下面为部分代码预览,完整代码请点击下载或在bfwstudio webide中打开
<!DOCTYPE html>
<html lang="zh-CN">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>教务管理系统 (完整版)</title>
<script type="text/javascript" src="//repo.bfw.wiki/bfwrepo/js/vue3.2.22.js"></script>
<style>
:root {
--primary-color: #409EFF;
--sidebar-bg: #304156;
--sidebar-text: #BFCBD9;
--sidebar-active-text: #409EFF;
--header-bg: #fff;
--content-bg: #f0f2f5;
--text-color: #303133;
--border-color: #DCDFE6;
--card-shadow: 0 1px 3px rgba(0,0,0,0.02), 0 1px 2px rgba(0,0,0,0.05);
--success-color: #67C23A;
--danger-color: #F56C6C;
}
body, html {
margin: 0; padding: 0;
font-family: "Helvetica Neue", Helvetica, "PingFang SC", "Hiragino Sans GB", "Microsoft YaHei", "微软雅黑", Arial, sans-serif;
background-color: var(--content-bg);
color: var(--text-color);
height: 100%;
overflow: hidden;
}
#app { display: flex; height: 100vh; }
/* --- Layout --- */
.sidebar { width: 210px; background-color: var(--sidebar-bg); transition: width 0.28s; flex-shrink: 0; display: flex; flex-direction: column; }
.sidebar.collapsed { width: 64px; }
.sidebar-header {
height: 60px; display: flex; align-items: center; justify-content: center; color: #fff;
font-size: 18px; font-weight: bold; white-space: nowrap; overflow: hidden;
}
.sidebar-header .logo { width: 32px; height: 32px; margin-right: 10px; }
.sidebar.collapsed .logo { margin: 0; }
.sidebar.collapsed .title { display: none; }
.nav-menu { list-style: none; padding: 0; margin: 8px 0; flex-grow: 1; }
.nav-item {
display: flex; align-items: center; height: 56px; padding-left: 20px;
color: var(--sidebar-text); cursor: pointer; transition: background-color 0.2s, color 0.2s;
white-space: nowrap; overflow: hidden;
}
.nav-item:hover { background-color: #263445; }
.nav-item.active {
color: var(--sidebar-active-text); background-color: #263445;
border-right: 3px solid var(--primary-color);
}
.nav-item svg { width: 18px; height: 18px; margin-right: 16px; }
.sidebar.collapsed .nav-item { padding-left: 0; justify-content: center; }
.sidebar.collapsed .nav-item svg { margin-right: 0; }
.sidebar.collapsed .nav-item .text { display: none; }
.main-wrapper { flex-grow: 1; display: flex; flex-direction: column; height: 100vh; overflow: hidden; }
.top-header {
height: 60px; background-color: var(--header-bg); box-shadow: 0 1px 4px rgba(0, 21, 41, 0.08);
display: flex; align-items: center; justify-content: space-between; padding: 0 20px; flex-shrink: 0; z-index: 1;
}
.header-left .collapse-btn { cursor: pointer; font-size: 22px; color: #606266; }
.header-right { display: flex; align-items: center; }
.user-profile { display: flex; align-items: center; cursor: pointer; }
.user-profile img { width: 36px; height: 36px; border-radius: 50%; margin-right: 10px; }
.main-content { flex-grow: 1; padding: 20px; overflow-y: auto; }
/* --- Components --- */
.page-header { display: flex; justify-content: space-between; align-items: center; margin-bottom: 20px; }
.page-title { font-size: 20px; font-weight: 500; }
.page-actions { display: flex; gap: 10px; }
.card {
background: #fff; padding: 20px; border-radius: 4px;
border: 1px solid var(--border-color); box-shadow: var(--card-shadow); margin-bottom: 20px;
}
.data-table { width: 100%; border-collapse: collapse; }
.data-table th, .data-table td { padding: 12px 15px; text-align: left; border-bottom: 1px solid #EBEEF5; }
.data-table th { background-color: #FAFAFA; font-weight: 500; color: #909399; }
.data-table tbody tr:hover { background-color: #F5F7FA; }
.button {
display: inline-flex; align-items: center; justify-content: center;
padding: 9px 20px; border: 1px solid var(--primary-color); border-radius: 4px;
background-color: var(--primary-color); color: white; font-size: 14px;
cursor: pointer; transition: all 0.2s;
}
.button svg { margin-right: 6px; }
.button:hover { filter: brightness(1.1); }
.button.plain { background-color: #ecf5ff; color: var(--primary-color); border-color: #b3d8ff; }
.button.danger { background-color: var(--danger-color); border-color: var(--danger-color); }
.form-input, .form-select {
width: 100%; padding: 8px 12px; font-size: 14px; border: 1px solid var(--border-color);
border-radius: 4px; box-sizing: border-box; transition: border-color .2s;
}
.form-input:focus, .form-select:focus { border-color: var(--primary-color); outline: none; }
.search-input { width: 240px; }
/* Modal */
.modal-overlay {
position: fixed; top: 0; left: 0; width: 100%; height: 100%;
background-color: rgba(0, 0, 0, 0.5); display: flex; align-items: flex-start; justify-content: center;
padding-top: 15vh; z-index: 1000;
}
.modal-content {
background: #fff; padding: 0; border-radius: 6px; width: 600px;
box-shadow: 0 5px 15px rgba(0,0,0,0.3);
}
.modal-header { padding: 15px 20px; font-size: 18px; font-weight: 500; border-bottom: 1px solid var(--border-color); }
.modal-body { padding: 20px; }
.form-group { display: flex; align-items: center; margin-bottom: 15px; }
.form-group label { width: 100px; text-align: right; margin-right: 15px; flex-shrink: 0; }
.form-group .control { flex: 1; }
.modal-footer { padding: 15px 20px; text-align: right; border-top: 1px solid var(--border-color); }
/* Transitions */
.fade-enter-active, .fade-leave-active { transition: opacity 0.2s ease; }
.fade-enter-from, .fade-leave-to { opacity: .........完整代码请登录后点击上方下载按钮下载查看
















网友评论0