设计理念与目标

  • 专业性: 界面干净、布局清晰,符合企业级应用标准。
  • 易用性: 信息层级分明,用户可以快速找到所需功能,操作直观。
  • 响应式: 在桌面、平板和手机上都能有良好的显示效果。
  • 可扩展性: 模块化的设计,方便您后续添加新功能,如设备详情页、报表、设置等。

模板结构与核心模块

我们将模板分为以下几个主要区域:

设备管理dreamweaver模板
(图片来源网络,侵删)
  1. 顶部导航栏: 包含Logo、主导航菜单(如:设备概览、添加设备、报表、设置)和用户信息。
  2. 侧边栏: 主要功能导航,可以折叠,以扩大主要内容区域。
  3. 区:
    • 当前页面的标题和操作按钮(如“添加新设备”)。
    • 统计卡片: 显示关键数据(如设备总数、在线数、故障数、待维修数)。
    • 设备列表: 以表格形式展示所有设备,支持排序和搜索。
    • 分页控件: 用于浏览大量设备数据。
  4. 页脚: 显示版权信息和系统版本。

Dreamweaver 模板实现步骤

Dreamweaver模板的核心是 可编辑区域不可编辑区域,我们将在模板文件中定义好布局,然后创建基于该模板的页面。

第一步:创建模板文件

  1. 打开 Adobe Dreamweaver。
  2. 选择 文件 > 新建,在“页面类型”中选择 HTML,然后点击“创建”。
  3. 将新文件另存为 Templates/master.dwt.html,Dreamweaver会自动在站点中创建一个 Templates 文件夹。

第二步:构建模板的HTML结构

master.dwt.html 中,输入以下完整的HTML代码,我已经为您准备好了,包含了内联的CSS和基础的JavaScript。

<!DOCTYPE html>
<html lang="zh-CN">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">设备管理系统</title>
    <!-- 内联CSS样式 -->
    <style>
        /* --- 全局样式 --- */
        * {
            margin: 0;
            padding: 0;
            box-sizing: border-box;
            font-family: 'Segoe UI', Tahoma, Geneva, Verdana, sans-serif;
        }
        body {
            background-color: #f4f7f6;
            color: #333;
        }
        .container {
            display: flex;
            min-height: 100vh;
        }
        .content-wrapper {
            flex: 1;
            display: flex;
            flex-direction: column;
        }
        /* --- 顶部导航栏 --- */
        .top-navbar {
            background-color: #2c3e50;
            color: white;
            padding: 0 20px;
            display: flex;
            justify-content: space-between;
            align-items: center;
            height: 60px;
            box-shadow: 0 2px 4px rgba(0,0,0,0.1);
        }
        .logo {
            font-size: 24px;
            font-weight: bold;
        }
        .user-info {
            display: flex;
            align-items: center;
            gap: 15px;
        }
        .user-info a {
            color: white;
            text-decoration: none;
        }
        /* --- 侧边栏 --- */
        .sidebar {
            width: 250px;
            background-color: #34495e;
            padding: 20px 0;
            color: white;
            transition: margin-left 0.3s;
        }
        .sidebar-item {
            padding: 15px 25px;
            cursor: pointer;
            display: flex;
            align-items: center;
            gap: 10px;
        }
        .sidebar-item:hover, .sidebar-item.active {
            background-color: #2c3e50;
        }
        .sidebar-toggle {
            display: none; /* 默认隐藏,用于移动端 */
            background: none;
            border: none;
            color: white;
            font-size: 24px;
            cursor: pointer;
        }
        /* --- 主内容区 --- */
        .main-content {
            padding: 25px;
            flex: 1;
        }
        .page-header {
            display: flex;
            justify-content: space-between;
            align-items: center;
            margin-bottom: 25px;
        }
        .page-title {
            font-size: 28px;
            color: #2c3e50;
        }
        .btn {
            padding: 10px 20px;
            border: none;
            border-radius: 5px;
            cursor: pointer;
            font-size: 16px;
            transition: background-color 0.3s;
        }
        .btn-primary {
            background-color: #3498db;
            color: white;
        }
        .btn-primary:hover {
            background-color: #2980b9;
        }
        /* --- 统计卡片 --- */
        .stats-container {
            display: grid;
            grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
            gap: 20px;
            margin-bottom: 30px;
        }
        .stat-card {
            background: white;
            padding: 20px;
            border-radius: 8px;
            box-shadow: 0 2px 10px rgba(0,0,0,0.05);
            display: flex;
            justify-content: space-between;
            align-items: center;
        }
        .stat-info h3 {
            font-size: 32px;
            font-weight: bold;
            color: #2c3e50;
        }
        .stat-info p {
            color: #7f8c8d;
            margin-top: 5px;
        }
        .stat-icon {
            font-size: 40px;
        }
        /* --- 设备列表表格 --- */
        .table-container {
            background: white;
            border-radius: 8px;
            box-shadow: 0 2px 10px rgba(0,0,0,0.05);
            overflow: hidden;
        }
        .table-header {
            padding: 20px;
            border-bottom: 1px solid #ecf0f1;
            display: flex;
            justify-content: space-between;
            align-items: center;
        }
        .search-box {
            padding: 8px 15px;
            border: 1px solid #ddd;
            border-radius: 5px;
            width: 300px;
        }
        table {
            width: 100%;
            border-collapse: collapse;
        }
        th, td {
            padding: 15px;
            text-align: left;
            border-bottom: 1px solid #ecf0f1;
        }
        th {
            background-color: #f8f9fa;
            font-weight: 600;
            color: #2c3e50;
        }
        tr:hover {
            background-color: #f8f9fa;
        }
        .status-badge {
            padding: 5px 12px;
            border-radius: 20px;
            font-size: 12px;
            font-weight: bold;
        }
        .status-online { background-color: #d4edda; color: #155724; }
        .status-offline { background-color: #f8d7da; color: #721c24; }
        .status-maintenance { background-color: #fff3cd; color: #856404; }
        /* --- 分页 --- */
        .pagination {
            padding: 20px;
            display: flex;
            justify-content: center;
            gap: 10px;
        }
        .pagination a {
            padding: 8px 12px;
            border: 1px solid #ddd;
            border-radius: 5px;
            color: #2c3e50;
            text-decoration: none;
        }
        .pagination a.active {
            background-color: #3498db;
            color: white;
            border-color: #3498db;
        }
        /* --- 响应式设计 --- */
        @media (max-width: 768px) {
            .container {
                flex-direction: column;
            }
            .sidebar {
                width: 100%;
                position: fixed;
                top: 60px;
                left: -100%;
                z-index: 1000;
            }
            .sidebar.active {
                left: 0;
            }
            .sidebar-toggle {
                display: block;
            }
            .page-header {
                flex-direction: column;
                align-items: flex-start;
                gap: 15px;
            }
            .search-box {
                width: 100%;
            }
            .stats-container {
                grid-template-columns: 1fr;
            }
        }
    </style>
</head>
<body>
    <div class="container">
        <!-- 顶部导航栏 - 不可编辑区域 -->
        <header class="top-navbar">
            <div>
                <button class="sidebar-toggle" id="sidebarToggle">☰</button>
                <span class="logo">设备管理系统</span>
            </div>
            <div class="user-info">
                <a href="#">管理员</a>
                <a href="#">退出</a>
            </div>
        </header>
        <div class="content-wrapper">
            <!-- 侧边栏 - 不可编辑区域 -->
            <aside class="sidebar" id="sidebar">
                <div class="sidebar-item active">
                    <span>📊</span> <span>设备概览</span>
                </div>
                <div class="sidebar-item">
                    <span>➕</span> <span>添加设备</span>
                </div>
                <div class="sidebar-item">
                    <span>📋</span> <span>设备列表</span>
                </div>
                <div class="sidebar-item">
                    <span>📈</span> <span>数据报表</span>
                </div>
                <div class="sidebar-item">
                    <span>⚙️</span> <span>系统设置</span>
                </div>
            </aside>
            <!-- 主内容区 - 可编辑区域 -->
            <main class="main-content">
                <!-- 页面标题和操作按钮 - 可编辑区域 -->
                <div class="page-header">
                    <h1 class="page-title">设备概览</h1>
                    <button class="btn btn-primary">添加新设备</button>
                </div>
                <!-- 统计卡片 - 可编辑区域 -->
                <div class="stats-container">
                    <div class="stat-card">
                        <div class="stat-info">
                            <h3>156</h3>
                            <p>设备总数</p>
                        </div>
                        <div class="stat-icon">🖥️</div>
                    </div>
                    <div class="stat-card">
                        <div class="stat-info">
                            <h3>142</h3>
                            <p>在线设备</p>
                        </div>
                        <div class="stat-icon">✅</div>
                    </div>
                    <div class="stat-card">
                        <div class="stat-info">
                            <h3>8</h3>
                            <p>故障设备</p>
                        </div>
                        <div class="stat-icon">❌</div>
                    </div>
                    <div class="stat-card">
                        <div class="stat-info">
                            <h3>6</h3>
                            <p>待维修</p>
                        </div>
                        <div class="stat-icon">🔧</div>
                    </div>
                </div>
                <!-- 设备列表 - 可编辑区域 -->
                <div class="table-container">
                    <div class="table-header">
                        <h2>设备列表</h2>
                        <input type="text" class="search-box" placeholder="搜索设备名称、ID或型号...">
                    </div>
                    <table>
                        <thead>
                            <tr>
                                <th>设备ID</th>
                                <th>设备名称</th>
                                <th>型号</th>
                                <th>位置</th>
                                <th>状态</th>
                                <th>最后在线</th>
                                <th>操作</th>
                            </tr>
                        </thead>
                        <tbody>
                            <tr>
                                <td>DEV-001</td>
                                <td>服务器-A</td>
                                <td>Dell R740</td>
                                <td>机房-1</td>
                                <td><span class="status-badge status-online">在线</span></td>
                                <td>2025-10-27 14:30</td>
                                <td><a href="#">详情</a> | <a href="#">编辑</a></td>
                            </tr>
                            <tr>
                                <td>DEV-002</td>
                                <td>工作站-B</td>
                                <td>HP Z4</td>
                                <td>办公区-2</td>
                                <td><span class="status-badge status-offline">离线</span></td>
                                <td>2025-10-26 18:00</td>
                                <td><a href="#">详情</a> | <a href="#">编辑</a></td>
                            </tr>
                            <tr>
                                <td>DEV-003</td>
                                <td>打印机-C</td>
                                <td>Canon iR-ADV C3550</td>
                                <td>办公区-3</td>
                                <td><span class="status-badge status-maintenance">维护中</span></td>
                                <td>2025-10-25 09:15</td>
                                <td><a href="#">详情</a> | <a href="#">编辑</a></td>
                            </tr>
                        </tbody>
                    </table>
                </div>
                <!-- 分页 - 可编辑区域 -->
                <div class="pagination">
                    <a href="#" class="active">1</a>
                    <a href="#">2</a>
                    <a href="#">3</a>
                    <a href="#">下一页 &gt;</a>
                </div>
            </main>
        </div>
    </div>
    <!-- 简单的JavaScript用于侧边栏切换 -->
    <script>
        document.getElementById('sidebarToggle').addEventListener('click', function() {
            document.getElementById('sidebar').classList.toggle('active');
        });
    </script>
</body>
</html>

第三步:定义可编辑区域

这是Dreamweaver模板的关键,在上面的代码中,我们将所有需要根据不同页面变化的内容都放在了 main-content 区域内。

  1. 在Dreamweaver的设计视图中,选中 main-content 区域内的所有HTML元素(从 <div class="page-header"> 到最后的 </div>)。
  2. 在Dreamweaver的顶部菜单栏中,选择 插入 > 模板对象 > 可编辑区域
  3. 在弹出的对话框中,为该区域命名,EditRegion1,Dreamweaver会自动用高亮颜色(通常是浅蓝色)标记出可编辑区域。

您的 master.dwt.html 模板就创建完成了。top-navbarsidebar 是固定的,而 main-content 内部的内容可以在基于此模板创建的页面中自由修改。

设备管理dreamweaver模板
(图片来源网络,侵删)

第四步:使用模板创建新页面

  1. 在Dreamweaver中,选择 文件 > 新建
  2. 在“页面类型”中选择 模板,然后从右侧的“模板文件夹”中选择您刚刚创建的 Templates 文件夹,并点击 master.dwt.html
  3. 点击“创建”,Dreamweaver会生成一个基于模板的新HTML文件,index.html
  4. 在这个新文件中,您只能修改被标记为可编辑区域(EditRegion1,尝试修改顶部导航栏或侧边栏,会发现它们是被锁定的。

您可以为“设备列表”、“添加设备”、“数据报表”等页面分别创建基于 master.dwt.html 的新页面,然后只修改它们各自的 EditRegion1 内容,从而保持整个网站风格的一致性。


模板使用与后续开发建议

  1. 交互功能: 当前模板是静态的,要实现真正的功能,您需要:

    • 后端: 使用Node.js, PHP, Python (Django/Flask) 等技术来处理数据逻辑、数据库交互(MySQL, PostgreSQL等)和用户认证。
    • 前端: 将静态HTML表格替换为由JavaScript(如使用Vue.js, React, 或原生JS)动态生成的组件,以便从服务器API获取数据并渲染。
    • 后端API: 设计RESTful API,用于获取设备列表、添加设备、更新设备状态等。
  2. Dreamweaver的现代替代品: 虽然Dreamweaver的模板功能依然可用,但现代Web开发更倾向于使用组件化框架(如Vue, React)或静态站点生成器(如Hugo, Jekyll),它们提供了更强大、更灵活的开发体验。

  3. 美化与细节:

    设备管理dreamweaver模板
    (图片来源网络,侵删)
    • 图标库: 引入 Font Awesome 或 Material Icons 等图标库,让界面更专业。
    • 动画: 添加CSS过渡效果,如侧边栏滑入滑出、按钮悬停效果等,提升用户体验。
    • 数据可视化: 在“数据报表”页面,可以使用 ECharts 或 Chart.js 等库来生成图表。

这个模板为您提供了一个坚实的起点,您可以基于它进行快速开发和迭代,祝您项目顺利!