news 2025/12/17 11:15:21

jQuery EasyUI 拖放 - 创建学校课程表

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
jQuery EasyUI 拖放 - 创建学校课程表

jQuery EasyUI 拖放 - 创建学校课程表

使用jQuery EasyUIdraggabledroppable插件,可以轻松实现一个交互式的学校课程表(Timetable)。左侧显示可选课程科目,用户可以将科目拖动到右侧的课程表单元格中安排课表。支持从左侧拖入(克隆添加)和在课程表内拖动调整位置。

这个示例模拟一个简单的排课系统:左侧是课程列表,右侧是按星期和节次划分的表格。

官方教程参考:https://www.jeasyui.com/tutorial/dd/dnd3.php
在线 Demo:https://www.jeasyui.com/tutorial/dd/dnd3_demo.html

步骤 1: 引入 EasyUI 资源
<linkrel="stylesheet"type="text/css"href="https://www.jeasyui.com/easyui/themes/default/easyui.css"><linkrel="stylesheet"type="text/css"href="https://www.jeasyui.com/easyui/themes/icon.css"><scripttype="text/javascript"src="https://code.jquery.com/jquery-1.12.4.min.js"></script><scripttype="text/javascript"src="https://www.jeasyui.com/easyui/jquery.easyui.min.js"></script>
步骤 2: 创建 HTML 结构

左侧课程区(多个可拖动 div),右侧课程表(table 的 td 为放置区)。

<divstyle="margin:20px 0;"></div><divclass="easyui-panel"style="width:800px;padding:10px;"><tablestyle="width:100%"><tr><tdvalign="top"><h3>可选课程</h3><divclass="item">语文<br>Teacher: Mr.Wang</div><divclass="item">数学<br>Teacher: Mr.Xu</div><divclass="item">英语<br>Teacher: Miss.Liu</div><divclass="item">物理<br>Teacher: Mr.Zhao</div><divclass="item">化学<br>Teacher: Mr.Chen</div><divclass="item">体育<br>Teacher: Mr.Li</div></td><tdvalign="top"style="padding-left:50px;"><h3>课程表</h3><tableclass="timetable"><tr><th></th><th>星期一</th><th>星期二</th><th>星期三</th><th>星期四</th><th>星期五</th></tr><tr><td>第1节</td><tdclass="drop"></td><tdclass="drop"></td><tdclass="drop"></td><tdclass="drop"></td><tdclass="drop"></td></tr><tr><td>第2节</td><tdclass="drop"></td><tdclass="drop"></td><tdclass="drop"></td><tdclass="drop"></td><tdclass="drop"></td></tr><tr><td>第3节</td><tdclass="drop"></td><tdclass="drop"></td><tdclass="drop"></td><tdclass="drop"></td><tdclass="drop"></td></tr><tr><td>第4节</td><tdclass="drop"></td><tdclass="drop"></td><tdclass="drop"></td><tdclass="drop"></td><tdclass="drop"></td></tr><tr><td>第5节</td><tdclass="drop"></td><tdclass="drop"></td><tdclass="drop"></td><tdclass="drop"></td><tdclass="drop"></td></tr></table></td></tr></table></div><style>.item{width:120px;height:60px;margin:10px;padding:10px;text-align:center;background:#fafafa;border:1px solid #ccc;cursor:move;}.timetable th, .timetable td{border:1px solid #ccc;padding:10px;text-align:center;width:100px;height:80px;vertical-align:top;}.timetable .drop{background:#fff;}.timetable .over{background:#ff0;}</style>
步骤 3: JavaScript 实现拖放逻辑

使课程可拖动(clone 代理),课程表单元格可放置;从左侧拖入克隆添加,从表格内拖动则移动。

<scripttype="text/javascript">$(function(){// 左侧课程可拖动(克隆)$('.item').draggable({revert:true,proxy:'clone',onStartDrag:function(){$(this).draggable('options').cursor='not-allowed';},onStopDrag:function(){$(this).draggable('options').cursor='move';}});// 课程表单元格可放置$('.timetable td.drop').droppable({onDragEnter:function(e,source){$(this).addClass('over');},onDragLeave:function(e,source){$(this).removeClass('over');},onDrop:function(e,source){$(this).removeClass('over');if($(source).hasClass('assigned')){// 从表格内拖动:移动$(this).append(source);}else{// 从左侧拖入:克隆添加varclone=$(source).clone().addClass('assigned');$(this).empty().append(clone);clone.draggable({revert:true// 允许在表格内继续拖动调整});}}});});</script>
关键说明
  • 从左侧拖入:使用proxy:'clone',放置时克隆课程并添加assigned类,标记已安排。
  • 在表格内调整:已安排的课程(.assigned)拖动时直接移动元素。
  • 视觉反馈:拖入单元格时高亮(.over类)。
  • revert: true:无效放置时回弹。
  • 优势:直观排课,支持调整位置,可扩展清除/保存功能。
扩展建议
  • 添加“清除”按钮:在单元格右键或双击清除课程。
  • 支持保存:拖放后收集所有安排的课程,AJAX 提交到后端。
  • 防止重复/冲突:onDrop 时检查单元格是否已有课程。
  • 更多节次/星期:动态生成表格。

更多示例:

  • 官方学校课程表示例:https://www.jeasyui.com/tutorial/dd/dnd3.php
  • Demo 下载:可在官方教程页查找 ZIP。

如果需要添加保存功能、冲突检测、完整源码,或更多课程数据,请提供更多细节!

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2025/12/17 11:15:19

jQuery EasyUI 菜单与按钮 - 创建简单的菜单

jQuery EasyUI 菜单与按钮 - 创建简单的菜单 jQuery EasyUI 提供了强大的 Menu&#xff08;菜单&#xff09;和 LinkButton&#xff08;链接按钮&#xff09;组件。本教程将展示如何创建最基本的下拉菜单&#xff08;包括顶级菜单和子菜单&#xff09;、上下文菜单&#xff08…

作者头像 李华
网站建设 2025/12/17 11:14:34

编程新人别硬卷!网安:起薪高20%,3年就能当骨干

为什么说学编程不如直接去学网络安全&#xff1f; 一、先看一组扎心对比&#xff1a;市场真的不一样 程序员 &#xff1a;2024 智联招聘数据显示&#xff0c;Java 开发岗平均 1 岗 38 人竞争&#xff0c;应届生起薪中位数仅 7800 元&#xff1b;某大厂 2024 校招开发岗简历通过…

作者头像 李华
网站建设 2025/12/17 11:13:50

【Linux 基础知识系列:第二百零三篇】Linux 系统账户安全加固

一、简介&#xff1a;为什么要“折腾”账户安全&#xff1f;MITRE ATT&CK 矩阵把“Valid Accounts”列为 Top 1 入口&#xff1a;2022 年 80% 勒索软件通过 弱口令/爆破 root 入场。合规要求&#xff1a;等保 2.0 要求“默认账户管理、口令复杂度、权限最小化”。SOC2、ISO…

作者头像 李华
网站建设 2025/12/17 11:12:57

通达信彩带表示的macd

{}W:1; M:1; MM:9*M; SHORT:MM*4/3; LONG:MM*26/9; DIFF:(EMA(CLOSE,SHORT)-EMA(CLOSE,LONG)); DEA:EMA(DIFF,MM),COLOR58FF58; MACD:2*(DIFF-DEA),COLORFFFF00,LINETHICK0; 红柱:DRAWBAND(MACD,RGB(180,50,50),0,RGB(0,128,0)); 绿柱:DRAWBAND(0,RGB(0,128,0),MACD,RGB(180,50…

作者头像 李华
网站建设 2025/12/17 11:11:58

双机热备全景剖析:从技术原理到角色视角的深度解构【20251217】001篇

文章目录 双机热备全景剖析:从技术原理到角色视角的深度解构 开篇:为何“永不宕机”成为数字时代的生死线? 第一章 本源探究:3W1H框架解构双机热备核心 1.1 WHAT(是什么)—— 技术本质的多层透视 1.2 WHY(为什么)—— 业务连续性的数字经济学 1.3 WHERE(用在哪里)——…

作者头像 李华