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