热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

基于redipsdragmin.js拖动排课功能

基于redips-drag-min.js拖动排课功能最近在做一个功能,大致是,老师提交自己想要上的课和时间,然后管理员进行排课࿰


基于redips-drag-min.js拖动排课功能


最近在做一个功能,大致是,老师提交自己想要上的课和时间,然后管理员进行排课,每个课程在同一时间段可以有多个老师,老师需要排优先级,学生预约课程时,按老师优先级顺序进行确认上课。
开始的时候给客户做了一个勾选进行排课的,但是客户为了漂亮,刀架在脖子上非要拖动排课,于是只能勉为其难做了。废话不多说,开始阐述实现。
本功能主要用到一个第三方js,官方地址为:https://www.redips.net,大家可以进官网下载样例。

遇到的问题


  1. html中div包裹样式一定要按规定格式,其中id="redips-drag"的div包含了目标区域的table和拖动区域的table,需要拖动的div上边需要加上class=“redips-drag”,不能拖动的div上边加上class=“redips-mark”

<div class&#61;"row"><div id&#61;"main_container"><div id&#61;"redips-drag"><div id&#61;"weekTemplateDetail"><div class&#61;"dayTemplateDetail" id&#61;"dayTemplateDetail"><table id&#61;"templateTable" class&#61;"courseDetail">table>div> div><div id&#61;"lecturerSubmitInfoDetails"><div id&#61;"showDetail_div"><table id&#61;"table1" class&#61;"table submitInfoTable"><c:choose><c:when test&#61;"${not empty page.list }"><c:set var&#61;"temp" value&#61;"0">c:set><c:set var&#61;"brCount" value&#61;"4">c:set><c:choose><c:when test&#61;"${page.list.size()%brCount &#61;&#61; 0}"> <c:set var&#61;"end" value&#61;"${page.list.size()/brCount-1}">c:set>c:when><c:otherwise> <c:set var&#61;"end" value&#61;"${page.list.size()/brCount}">c:set>c:otherwise>c:choose><c:forEach begin&#61;"0" end&#61;"${end}"><tr><c:set var&#61;"num" value&#61;"0">c:set><c:forEach var&#61;"item" begin&#61;"${temp }" end&#61;"${temp&#43;brCount-1 }" items&#61;"${page.list}"><td class&#61;"redips-mark"><div class&#61;"redips-drag submitInfoDetail" id&#61;"${item.id }" data-timeState&#61;"${item.timeState }" data-timeZone&#61;"${item.timeZone }"data-lecturerId&#61;"${item.lecturerId }" data-itemId&#61;"${item.itemId }"><span>${item.lecturerName }(${fns:getDictLabel(item.pattern,&#39;consulting_type&#39;,&#39;&#39;)})span>br><span>${item.itemName }span>br><span>${item.timeZoneStr }span>div>td><c:set var&#61;"num" value&#61;"${num&#43;1 }">c:set>c:forEach><c:if test&#61;"${num"><c:forEach begin&#61;"1" end&#61;"${brCount-num }"><td class&#61;"redips-mark">td>c:forEach>c:if><c:set var&#61;"temp" value&#61;"${temp&#43;brCount }">c:set>tr>c:forEach>c:when><c:otherwise><tr><td colspan&#61;"1"><span>暂无没有可预约信息span>td>tr>c:otherwise>c:choose>table><div class&#61;"row">${page}div>div>div>div>
div>

  1. 在做的过程中出现了一个问题&#xff0c;能拖动相关课程信息&#xff0c;但是却放不到具体时间段上&#xff0c;由于本人是做java开发的&#xff0c;对html和js理解不深&#xff0c;一直以为是html写的有问题&#xff0c;后来在官网上找到问题的原因是在css上边&#xff0c;需要将id&#61;"redips-drag"的div设置 display&#61;“table”

#redips-drag {display: table; width: 100%;}

  1. 几个主要的js方法

&#39;use strict&#39;;let redips &#61; {}, // redips containerpos &#61; {}, // initial positions of DIV elementsrd &#61; REDIPS.drag; // reference to the REDIPS.drag lib// redips initialization
redips.init &#61; function () {// 初始化rd.init();rd.shift.animation &#61; true;redips.startPositions();rd.dropMode &#61; &#39;multiple&#39;;// 放下之前做的事件处理&#xff0c;需要验证是否符合时间段等&#xff0c;给出提示rd.event.droppedBefore &#61; function(targetCell){// 比对信息&#xff0c;是否可以放到此处var re &#61; checkCanDrop(rd, targetCell);console.log("re&#61;"&#43;re);if (!re) {return false;}return confirm(&#39;确定即进行预约信息设置&#xff0c;确定进行此操作吗&#xff1f;&#39;);}// 放下之后进行的操作rd.event.dropped &#61; function(targetCell){// ajax 保存操作var re &#61; dragAjaxSave(rd);console.log("re&#61;"&#43;re);// 保存完毕刷新页面左侧table内容//initTemplate();}// 双击进行删除rd.event.dblClicked &#61; function(){confirmx(&#39;确定要删除这条数据吗&#xff1f;&#39;, function(){if(isParent(rd.obj.id, &#39;&#39;)){console.log("执行了删除");deleteTemplate(rd); }else{console.log("没有执行删除"); }})}rd.event.deleted &#61; function(){}
};// 样例中带的不用修改&#xff0c;主要用于获取操作div
redips.startPositions &#61; function () {let divs, id, i, position;divs &#61; document.getElementById(&#39;redips-drag&#39;).getElementsByTagName(&#39;div&#39;);for (i &#61; 0; i < divs.length; i&#43;&#43;) {id &#61; divs[i].id;if (id) {position &#61; rd.getPosition(divs[i]);if (position.length > 0) {pos[id] &#61; position;}}}
};redips.toggleAnimation &#61; function (chk) {rd.shift.animation &#61; chk.checked;
};// add onload event listener
if (window.addEventListener) {window.addEventListener(&#39;load&#39;, redips.init, false);
}
else if (window.attachEvent) {window.attachEvent(&#39;onload&#39;, redips.init);
}

  1. 由于这个页面没有用到iframe进行布局&#xff0c;左边和右边的table在同一个页面上&#xff0c;然而左边和右边表格都涉及到了刷新的问题&#xff0c;刷新问题采取的方法是ajax带参发送请求&#xff0c;然后后端拼接html代码&#xff0c;然后前端进行table替换刷新

下面是完成之后的页面图&#xff1a;
在这里插入图片描述

遗留问题&#xff1a;如果在rd.event.dropped 函数中&#xff0c;即执行保存操作&#xff0c;也执行刷新操作时&#xff0c;会出现刷新出来的数据不显示当前保存的那一条信息&#xff0c;再次手动刷新时才会显示&#xff0c;希望有懂的小伙伴赐教&#xff0c;不胜感激。


推荐阅读
  • 本文介绍了闭包的定义和运转机制,重点解释了闭包如何能够接触外部函数的作用域中的变量。通过词法作用域的查找规则,闭包可以访问外部函数的作用域。同时还提到了闭包的作用和影响。 ... [详细]
  • PHP图片截取方法及应用实例
    本文介绍了使用PHP动态切割JPEG图片的方法,并提供了应用实例,包括截取视频图、提取文章内容中的图片地址、裁切图片等问题。详细介绍了相关的PHP函数和参数的使用,以及图片切割的具体步骤。同时,还提供了一些注意事项和优化建议。通过本文的学习,读者可以掌握PHP图片截取的技巧,实现自己的需求。 ... [详细]
  • 目录实现效果:实现环境实现方法一:基本思路主要代码JavaScript代码总结方法二主要代码总结方法三基本思路主要代码JavaScriptHTML总结实 ... [详细]
  • 单页面应用 VS 多页面应用的区别和适用场景
    本文主要介绍了单页面应用(SPA)和多页面应用(MPA)的区别和适用场景。单页面应用只有一个主页面,所有内容都包含在主页面中,页面切换快但需要做相关的调优;多页面应用有多个独立的页面,每个页面都要加载相关资源,页面切换慢但适用于对SEO要求较高的应用。文章还提到了两者在资源加载、过渡动画、路由模式和数据传递方面的差异。 ... [详细]
  • 本文介绍了pack布局管理器在Perl/Tk中的使用方法及注意事项。通过调用pack()方法,可以控制部件在显示窗口中的位置和大小。同时,本文还提到了在使用pack布局管理器时,应注意将部件分组以便在水平和垂直方向上进行堆放。此外,还介绍了使用Frame部件或Toplevel部件来组织部件在窗口内的方法。最后,本文强调了在使用pack布局管理器时,应避免在中间切换到grid布局管理器,以免造成混乱。 ... [详细]
  • GetWindowLong函数
    今天在看一个代码里头写了GetWindowLong(hwnd,0),我当时就有点费解,靠,上网搜索函数原型说明,死活找不到第 ... [详细]
  • JavaSE笔试题-接口、抽象类、多态等问题解答
    本文解答了JavaSE笔试题中关于接口、抽象类、多态等问题。包括Math类的取整数方法、接口是否可继承、抽象类是否可实现接口、抽象类是否可继承具体类、抽象类中是否可以有静态main方法等问题。同时介绍了面向对象的特征,以及Java中实现多态的机制。 ... [详细]
  • 本文讨论了一个关于cuowu类的问题,作者在使用cuowu类时遇到了错误提示和使用AdjustmentListener的问题。文章提供了16个解决方案,并给出了两个可能导致错误的原因。 ... [详细]
  • Python正则表达式学习记录及常用方法
    本文记录了学习Python正则表达式的过程,介绍了re模块的常用方法re.search,并解释了rawstring的作用。正则表达式是一种方便检查字符串匹配模式的工具,通过本文的学习可以掌握Python中使用正则表达式的基本方法。 ... [详细]
  • 本文介绍了PE文件结构中的导出表的解析方法,包括获取区段头表、遍历查找所在的区段等步骤。通过该方法可以准确地解析PE文件中的导出表信息。 ... [详细]
  • 本文讨论了如何在dotnet桌面(Windows)应用程序中添加图标。作者提到可以使用dotnet命令行工具与resource.rc文件一起使用来为标准.NET核心应用程序添加图标。作者还介绍了在创建控制台应用程序时如何编辑projeto1.csproj文件来添加图标。 ... [详细]
  • 本文介绍了在wepy中运用小顺序页面受权的计划,包含了用户点击作废后的从新受权计划。 ... [详细]
  • 模板引擎StringTemplate的使用方法和特点
    本文介绍了模板引擎StringTemplate的使用方法和特点,包括强制Model和View的分离、Lazy-Evaluation、Recursive enable等。同时,还介绍了StringTemplate语法中的属性和普通字符的使用方法,并提供了向模板填充属性的示例代码。 ... [详细]
  • 本文介绍了在MFC下利用C++和MFC的特性动态创建窗口的方法,包括继承现有的MFC类并加以改造、插入工具栏和状态栏对象的声明等。同时还提到了窗口销毁的处理方法。本文详细介绍了实现方法并给出了相关注意事项。 ... [详细]
  • 如何在HTML中获取鼠标的当前位置
    本文介绍了在HTML中获取鼠标当前位置的三种方法,分别是相对于屏幕的位置、相对于窗口的位置以及考虑了页面滚动因素的位置。通过这些方法可以准确获取鼠标的坐标信息。 ... [详细]
author-avatar
比刀郎还冲动啊
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有