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