热门标签 | 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;不胜感激。


推荐阅读
  • 本文探讨了如何通过优化 DOM 操作来提升 JavaScript 的性能,包括使用 `createElement` 函数、动画元素、理解重绘事件及处理鼠标滚动事件等关键主题。 ... [详细]
  • publicclassBindActionextendsActionSupport{privateStringproString;privateStringcitString; ... [详细]
  • H5技术实现经典游戏《贪吃蛇》
    本文将分享一个使用HTML5技术实现的经典小游戏——《贪吃蛇》。通过H5技术,我们将探讨如何构建这款游戏的两种主要玩法:积分闯关和无尽模式。 ... [详细]
  • 本文详细介绍了JQuery Mobile框架中特有的事件和方法,帮助开发者更好地理解和应用这些特性,提升移动Web开发的效率。 ... [详细]
  • 在尝试加载支持推送通知的iOS应用程序的Ad Hoc构建时,遇到了‘no valid aps-environment entitlement found for application’的错误提示。本文将探讨此错误的原因及多种可能的解决方案。 ... [详细]
  • 本文介绍了.hbs文件作为Ember.js项目中的视图层,类似于HTML文件的功能,并详细讲解了如何在Ember.js应用中集成Bootstrap框架及其相关组件的方法。 ... [详细]
  • 在1995年,Simon Plouffe 发现了一种特殊的求和方法来表示某些常数。两年后,Bailey 和 Borwein 在他们的论文中发表了这一发现,这种方法被命名为 Bailey-Borwein-Plouffe (BBP) 公式。该问题要求计算圆周率 π 的第 n 个十六进制数字。 ... [详细]
  • 长期从事ABAP开发工作的专业人士,在面对行业新趋势时,往往需要重新审视自己的发展方向。本文探讨了几位资深专家对ABAP未来走向的看法,以及开发者应如何调整技能以适应新的技术环境。 ... [详细]
  • 本文介绍了SIP(Session Initiation Protocol,会话发起协议)的基本概念、功能、消息格式及其实现机制。SIP是一种在IP网络上用于建立、管理和终止多媒体通信会话的应用层协议。 ... [详细]
  • 本文详细介绍了 `org.apache.tinkerpop.gremlin.structure.VertexProperty` 类中的 `key()` 方法,并提供了多个实际应用的代码示例。通过这些示例,读者可以更好地理解该方法在图数据库操作中的具体用途。 ... [详细]
  • 二维码的实现与应用
    本文介绍了二维码的基本概念、分类及其优缺点,并详细描述了如何使用Java编程语言结合第三方库(如ZXing和qrcode.jar)来实现二维码的生成与解析。 ... [详细]
  • Beetl是一款先进的Java模板引擎,以其丰富的功能、直观的语法、卓越的性能和易于维护的特点著称。它不仅适用于高响应需求的大型网站,也适合功能复杂的CMS管理系统,提供了一种全新的模板开发体验。 ... [详细]
  • 本文详细介绍了在Windows系统中如何配置Nginx以实现高效的缓存加速功能,包括关键的配置文件设置和示例代码。 ... [详细]
  • 问题描述现在,不管开发一个多大的系统(至少我现在的部门是这样的),都会带一个日志功能;在实际开发过程中 ... [详细]
  • 在开发一个网页音乐播放器时遇到问题,需要从不同源读取MP3文件的ID3标签信息,包括流派、歌手和歌曲名称等。尝试使用PHP未果后转而考虑使用JavaScript进行跨域读取,但不清楚具体配置方法,寻求技术指导。 ... [详细]
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社区 版权所有