jQuery EasyUI 拖放 - 创立校园课程表

本教程将向您展现怎么运用 jQuery EasyUI 创立一个校园课程表。 咱们将创立两个表格:在左边显现校园科目,在右侧显现时间表。 您能够拖动校园科目并放置到时间表单元格上。 校园科目是一个 <div class="item"> 元素,时间表单元格是一个 <td class="drop"> 元素。

显现校园科目

	<div class="left">
		<table>
			<tr>
				<td><div class="item">English</div></td>
			</tr>
			<tr>
				<td><div class="item">Science</div></td>
			</tr>
			<!-- other subjects -->
		</table>
	</div>

显现时间表

	<div class="right">
		<table>
			<tr>
				<td class="blank"></td>
				<td class="title">Monday</td>
				<td class="title">Tuesday</td>
				<td class="title">Wednesday</td>
				<td class="title">Thursday</td>
				<td class="title">Friday</td>
			</tr>
			<tr>
				<td class="time">08:00</td>
				<td class="drop"></td>
				<td class="drop"></td>
				<td class="drop"></td>
				<td class="drop"></td>
				<td class="drop"></td>
			</tr>
			<!-- other cells -->
		</table>
	</div>

拖动在左边的校园科目

	$('.left .item').draggable({
		revert:true,
		proxy:'clone'
	});

放置校园科目在时间表单元格上

	$('.right td.drop').droppable({
		onDragEnter:function(){
			$(this).addClass('over');
		},
		onDragLeave:function(){
			$(this).removeClass('over');
		},
		onDrop:function(e,source){
			$(this).removeClass('over');
			if ($(source).hasClass('assigned')){
				$(this).append(source);
			} else {
				var c = $(source).clone().addClass('assigned');
				$(this).empty().append(c);
				c.draggable({
					revert:true
				});
			}
		}
	});

正如您所看到的上面的代码,当用户拖动在左边的校园科目并放置到时间表单元格中时,onDrop 回调函数将被调用。咱们克隆从左边拖动的源元素并把它附加到时间表单元格上。 当把校园科目从时间表的某个单元格拖动到其他单元格,只需简略地移动它即可。

下载 jQuery EasyUI 实例

jeasyui-dd-timetable.zip