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


推荐阅读
  • 优化JavaScript中的多条件判断逻辑
    本文探讨了在JavaScript中遇到复杂逻辑判断时,如何通过不同的方法优化if/else或switch语句,以提高代码的可读性和可维护性。 ... [详细]
  • 本文介绍了一个优化过的JavaScript函数,用于从API获取电影信息并渲染到网页上,同时注册Service Worker以提升用户体验和性能。 ... [详细]
  • 实用正则表达式有哪些
    小编给大家分享一下实用正则表达式有哪些,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下 ... [详细]
  • 云函数与数据库API实现增删查改的对比
    本文将深入探讨使用云函数和数据库API实现数据操作(增删查改)的不同方法,通过详细的代码示例帮助读者更好地理解和掌握这些技术。文章不仅提供代码实现,还解释了每种方法的特点和适用场景。 ... [详细]
  • This post discusses an issue encountered while using the @name annotation in documentation generation, specifically regarding nested class processing and unexpected output. ... [详细]
  • 本文详细介绍如何使用 HTML5 和 JavaScript 实现一个交互式的画板功能。通过具体代码示例,帮助读者理解 Canvas API 的基本用法及其在绘图应用中的实际应用。 ... [详细]
  • 探讨 HDU 1536 题目,即 S-Nim 游戏的博弈策略。通过 SG 函数分析游戏胜负的关键,并介绍如何编程实现解决方案。 ... [详细]
  • 在高并发需求的C++项目中,我们最初选择了JsonCpp进行JSON解析和序列化。然而,在处理大数据量时,JsonCpp频繁抛出异常,尤其是在多线程环境下问题更为突出。通过分析发现,旧版本的JsonCpp存在多线程安全性和性能瓶颈。经过评估,我们最终选择了RapidJSON作为替代方案,并实现了显著的性能提升。 ... [详细]
  • 本文介绍了如何在React和React Native项目中使用JavaScript进行日期格式化,提供了获取近7天、近半年及近一年日期的具体实现方法。 ... [详细]
  • 本文探讨了如何在JavaScript中动态地引用由PHP生成的变量,特别是在循环中变量名随迭代变化的情况。通过示例代码展示了实现这一功能的具体步骤。 ... [详细]
  • 本文将探讨从ASP.NET 1.1到2.0期间编译系统的重要变革。通过对比两个版本的即时编译模型,我们将揭示2.0版本中引入的新特性和改进之处。 ... [详细]
  • 9个提高JavaScript 技能必须知道的数组方法
    英文|https:javascript.plainenglish.io9-must-know-array-methods-to-boost-your-javascript-skil ... [详细]
  • C#反射reflection
    C#shanzm目录简介引入1.新建类库2.类库的使用3.反射反射实例1反射实例2反射实例3简介反射(reflection)是什么?在《精通C#》中是这么说的“反射就是一个运行库发 ... [详细]
  • 本文深入探讨了在Java编程语言中,如何使用`org.apache.polygene.api.association.AssociationDescriptor.qualifiedName()`方法,并提供了多个实际应用的代码示例。这些示例源自GitHub、StackOverflow和Maven等知名平台,旨在帮助开发者更好地理解和应用这一方法。 ... [详细]
  • 在日常开发中,经常需要通过Web服务进行数据交互。然而,在参数传递时会遇到一些限制,例如自定义实体类和Hashtable等复杂数据类型无法直接传递。本文将详细介绍如何在ASP.NET环境中有效地传递Hashtable数据。 ... [详细]
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社区 版权所有