Easyui+MVC+FullCalendar插件实现日程记录功能
好久好久好久,,,没有写博客了,,久到账号都忘记了。。。。分享一个干货。。。。
废话少说,先看看效果图。
要实现这样一个功能,先创建一个用于存储日程的记录表(不要问我为什么都是大写,因为初版在oracle中,现在在sqlserver,,哈哈哈哈,,,断气了,,,,我先缓缓。。。),大概如下:

前端view主要代码,表单控件我做了进一步封装(每次都写控件太太费劲了,,,,,我比较懒。。。。),亲在使用过程中替换成自己的表单控件即可。
<div class="toolbar">
<a href="javascript:void(0)" id="btnAdd" class="easyui-linkbutton" plain="true" iconcls="icon-add"
onclick="NewCalendar()">新建</a>
<a href="javascript:void(0)" id="btnQuery" class="easyui-linkbutton" plain="true"
iconcls="icon-search" onclick="OpenQueryPage()">查询</a>
</div>
<div id="calendar" style="width: 950px;margin: 10px auto;"></div> <div id="OpenQuery" class="easyui-window" style="width: 850px; height: 510px;" closed="true">
</div>
<div style="display: none">
<div id="dlg_All" style="width: 380px; height: 450px;">
<form id="dlg_ff" method="post" action="">
<input id="hdCalendar_Id" type="hidden" name="Calendar_Id" />
<table class="table">
<tr>
<td class="tdt">
@Html.EULabel("开始日期:", "Start_Date")
</td>
<td class="tdv">
@Html.EUTextBox_Date("Start_Date","")
</td>
</tr>
<tr>
<td class="tdt">
@Html.EULabel("开始时间:", "Start_Time")
</td>
<td class="tdv">
@Html.EUTextBox_Time("Start_Time", "")
</td>
</tr>
<tr>
<td class="tdt">
@Html.EULabel("结束日期:", "End_Date")
</td>
<td class="tdv">
@Html.EUTextBox_Date("End_Date", "")
</td>
</tr>
<tr>
<td class="tdt">
@Html.EULabel("结束时间:", "End_Time")
</td>
<td class="tdv">
@Html.EUTextBox_Time("End_Time", "")
</td>
</tr>
<tr>
<td class="tdt">
@Html.EULabel("标题:", "Title")
</td>
<td class="tdv">
@Html.EUTextBox("Title", 50)
</td>
</tr>
<tr>
<td class="tdt">
@Html.EULabel("备注:", "Description")
</td>
<td class="tdv">
@Html.EUTextArea("Description", 200,"86%","80px",false)
</td>
</tr>
</table>
</form>
</div>
<div id="btns_All">
@Html.EUButton("btn_DlgAdd", "保存", "icon-ok", "AddSaveEvent()")
@Html.EUButton("btn_DlgEdit", "保存", "icon-ok", "EditSaveEvent()")
@Html.EUButton("btn_DlgDel", "删除", "icon-delete", "DeleteSaveEvent()")
@Html.EUButton("btn_DlgCancle", "清空", "icon-clear", "javascript:$('#dlg_All').find('form').form('clear');")
@Html.EUButton("btn_DlgClose", "关闭", "icon-off", "javascript:$('#dlg_All').dialog('close');")
</div>
</div>
对应js部分,代码全部贴出了,如下:
var dlg_All;
var dlg_OpenQuery;
$(function () {
dlg_All = $('#dlg_All');
dlg_All.dialog({
closed: true,
modal: true,
buttons: '#btns_All'
});
dlg_OpenQuery = $('#OpenQuery'); var date = new Date();
var d = date.getDate();
var m = date.getMonth();
var y = date.getFullYear(); $('#calendar').fullCalendar({
header: {
left: 'prev,next today',
center: 'title',
right: 'month,agendaWeek,agendaDay'
},
editable: false,
dayClick: function (date, allDay, jsEvent, view) {
AddCalendar($.fullCalendar.formatDate(date, "yyyyMMdd"));
},
eventMouseover: function (calEvent, jsEvent, view) {
var fstart = $.fullCalendar.formatDate(calEvent.start, "yyyy/MM/dd HH:mm");
var fend = $.fullCalendar.formatDate(calEvent.end, "yyyy/MM/dd HH:mm");
$(this).attr('title', fstart + " - " + fend + " " + "标题" + " : " + calEvent.title);
$(this).css('font-weight', 'normal');
},
eventClick: function (event) {
OpenCalendar(event.id);
},
events: function (start, end, callback) {
var datestart = $.fullCalendar.formatDate(start, "yyyyMMdd");
var dateend = $.fullCalendar.formatDate(end, "yyyyMMdd");
$.ajax({
url: '/Calendar_Base/CalDataList',
dataType: 'json',
cache: false,
data: {
start: datestart,
end: dateend
},
success: function (result) {
var events = [];
for (var i = 0; i < result.length; i++) {
events.push({
title: result[i].TITLE,
start: string2date(result[i].START_DATE, result[i].START_TIME),
end: string2date(result[i].END_DATE, result[i].END_TIME),
id: result[i].CALENDAR_ID
});
}
callback(events);
}
});
}
});
}); function string2date(dt, ti) {
var y = dt.substr(0, 4);
var m = dt.substr(4, 2);
var d = dt.substr(6, 2);
return new Date(Date.parse(y + '/' + m + '/' + d + ' ' + ti));
} function OpenQueryPage() {
dlg_OpenQuery.window({
closed: true,
modal: true,
title: '日程清单',
href: '/Calendar_Base/IndexQuery',
iconCls: 'icon-search',
minimizable: false,
maximizable: false,
collapsible: false
});
dlg_OpenQuery.window("open");
} function AddCalendar(pDate) {
$("#btn_DlgAdd").show(); //添加保存
$("#btn_DlgCancle").show(); //清空
$("#btn_DlgEdit").hide(); //编辑保存
$("#btn_DlgDel").hide(); //删除
dlg_All.dialog({
iconCls: 'icon-add',
title: '添加信息'
});
dlg_All.find('form').form('clear');
$("#Start_Date").datebox('setValue', pDate.toString());
$('#Start_Time').timespinner('setValue', '00:00');
$("#End_Date").datebox('setValue', pDate.toString());
$('#End_Time').timespinner('setValue', '23:59');
$('#dlg_ff').form('validate')
dlg_All.dialog('open');
} function OpenCalendar(pCalendar_Id) {
dlg_All.dialog({
iconCls: 'icon-edit',
title: '编辑信息'
});
$("#btn_DlgAdd").hide();
$("#btn_DlgCancle").hide();
$("#btn_DlgEdit").show();
$("#btn_DlgDel").show(); //删除
$('#dlg_ff').form('clear');
$('#dlg_ff').form('load', '/Calendar_Base/QueryOne?Calendar_Id=' + pCalendar_Id);
dlg_All.dialog('open');
} function NewCalendar() {
$("#btn_DlgAdd").show(); //添加保存
$("#btn_DlgCancle").show(); //清空
$("#btn_DlgEdit").hide(); //编辑保存
$("#btn_DlgDel").hide(); //删除
dlg_All.dialog({
iconCls: 'icon-add',
title: '添加信息'
});
dlg_All.find('form').form('clear');
dlg_All.dialog('open');
}; function EditSaveEvent() {
if ($('#dlg_ff').form('validate')) {
if ($("#Start_Date").datebox('getValue') > $("#End_Date").datebox('getValue')) {
showEuMsg("【开始日期】不能大于【结束日期】!", "warning");
return false;
}
if ($("#Start_Date").datebox('getValue') == $("#End_Date").datebox('getValue')) {
if ($('#Start_Time').timespinner('getValue') > $('#End_Time').timespinner('getValue')) {
showEuMsg("【开始时间】不能大于【结束时间】!", "warning");
return false;
}
}
$('#dlg_ff').form('submit', {
url: '/Calendar_Base/EditOne',
success: function (result) {
var data = eval('(' + result + ')');
if (data.success) {
dlg_All.dialog('close');
$("#calendar").fullCalendar('refetchEvents');
showEuMsg(data.msg, "success");
}
else
showEuMsg(data.msg, "error");
}
});
}
} function AddSaveEvent() {
if ($('#dlg_ff').form('validate')) {
if ($("#Start_Date").datebox('getValue') > $("#End_Date").datebox('getValue')) {
showEuMsg("【开始日期】不能大于【结束日期】!", "warning");
return false;
}
if ($("#Start_Date").datebox('getValue') == $("#End_Date").datebox('getValue')) {
if ($('#Start_Time').timespinner('getValue') > $('#End_Time').timespinner('getValue')) {
showEuMsg("【开始时间】不能大于【结束时间】!", "warning");
return false;
}
}
$('#dlg_ff').form('submit', {
url: '/Calendar_Base/AddOne',
success: function (result) {
var data = eval('(' + result + ')');
if (data.success) {
dlg_All.dialog('close');
$("#calendar").fullCalendar('refetchEvents');
showEuMsg(data.msg, "success");
}
else
showEuMsg(data.msg, "error");
}
});
}
}; function DeleteSaveEvent() {
var postData = {
Calendar_Id: $("#hdCalendar_Id").val()
}
$.messager.confirm("提示", "您确认删除选定的记录吗?", function (deleteAction) {
if (deleteAction) {
$.ajax({
url: "/Calendar_Base/DeleteOne",
type: "post",
data: postData,
cache: false,
dataType: "json",
success: function (result) {
if (result.success) {
dlg_All.dialog('close');
$("#calendar").fullCalendar('refetchEvents');
showEuMsg(result.msg, "success");
}
else
showEuMsg(result.msg, "error");
}
});
}
});
};
下面就是在对应的controller中写相关的处理事件即可,这里就不做说明了(接触过mvc的应该都会,,,不会。。。。。。。就看看得了。。。。)
fullcalendar下载地址:fullcalendar.rar
Easyui+MVC+FullCalendar插件实现日程记录功能的更多相关文章
- ASP.NET MVC5+EF6+EasyUI 后台管理系统(86)-日程管理-fullcalendar插件用法
前言 本文分享fullcalendar用法,最后面提供代码下载 说到日程管理,基于JQuery的插件FullCalendar当之无愧,完整的API稳定和调用方式,非常易于扩展!可以用于系统的个人历程管 ...
- 基于MVC4+EasyUI的Web开发框架经验总结(1)-利用jQuery Tags Input 插件显示选择记录
最近花了不少时间在重构和进一步提炼我的Web开发框架上,力求在用户体验和界面设计方面,和Winform开发框架保持一致,而在Web上,我主要采用EasyUI的前端界面处理技术,走MVC的技术路线,在重 ...
- fullcalendar插件日程管理
日程管理-fullcalendar插件用法 前言 本文分享fullcalendar用法,最后面提供代码下载 说到日程管理,基于JQuery的插件FullCalendar当之无愧,完整的API稳定和 ...
- (转)基于MVC4+EasyUI的Web开发框架经验总结(1)-利用jQuery Tags Input 插件显示选择记录
http://www.cnblogs.com/wuhuacong/p/3667703.html 最近花了不少时间在重构和进一步提炼我的Web开发框架上,力求在用户体验和界面设计方面,和Winform开 ...
- jQuery Tags Input 插件显示选择记录
利用jQuery Tags Input 插件显示选择记录 最近花了不少时间在重构和进一步提炼我的Web开发框架上,力求在用户体验和界面设计方面,和Winform开发框架保持一致,而在Web上,我主要采 ...
- 从零开始实现ASP.NET Core MVC的插件式开发(三) - 如何在运行时启用组件
标题:从零开始实现ASP.NET Core MVC的插件式开发(三) - 如何在运行时启用组件 作者:Lamond Lu 地址:https://www.cnblogs.com/lwqlun/p/112 ...
- 从零开始实现ASP.NET Core MVC的插件式开发(四) - 插件安装
标题:从零开始实现ASP.NET Core MVC的插件式开发(四) - 插件安装 作者:Lamond Lu 地址:https://www.cnblogs.com/lwqlun/p/11260750. ...
- 从零开始实现ASP.NET Core MVC的插件式开发(五) - 插件的删除和升级
标题:从零开始实现ASP.NET Core MVC的插件式开发(五) - 使用AssemblyLoadContext实现插件的升级和删除 作者:Lamond Lu 地址:https://www.cnb ...
- Asp.NET MVC 使用 SignalR 实现推送功能二(Hubs 在线聊天室 获取保存用户信息)
简单介绍 关于SignalR的简单实用 请参考 Asp.NET MVC 使用 SignalR 实现推送功能一(Hubs 在线聊天室) 在上一篇中,我们只是介绍了简单的消息推送,今天我们来修改一下,实现 ...
随机推荐
- shell脚本中$参数的介绍
$$Shell本身的PID(ProcessID)$!Shell最后运行的后台Process的PID$?最后运行的命令的结束代码(返回值)$-使用Set命令设定的Flag一览$*所有参数列表.如&quo ...
- 生成JSON数据--fastjson(阿里)方法
fastjson(阿里)方法生成JSON数据: 与Gson类似,创建相应类,再使用JSON.toJSONString()添加对象 要求:生成如下JSON数据 1.{"age":3, ...
- javaSE_07Java中类和对象-封装特性--练习
1.编写封装一个学生类,有姓名,有年龄,有性别,有英语成绩,数学成绩,语文成绩,一个学生类,我们关注姓名,年龄,学历等信息,要求年龄必须在19-40岁之间,默认为19,学历必须是大专,本科,研究生这几 ...
- GLUT Trackball Demo
GLUT Trackball Demo eryar@163.com 1.Introduction 在三维场景中建立模型后,为了方便用户从各个角度观察模型,从而需要对三维视图进行控制.常见的视图交互控制 ...
- [转]html转码表
为什么要用转义字符串? HTML中<,>,&等有特殊含义(<,>,用于链接签,&用于转义),不能直接使用.这些符号是不显示在我们最终看到的网页里的,那如果我们希 ...
- php面向对象3
类的定义 基本定义 class 类名{ 访问修饰符 成员属性; 访问修饰符 成员方法; } 说明: ①类一定要class关键词修饰 ②类名的规范说明,使用大驼峰法 ③php 中,类名不区分大小写.但是 ...
- PHP 防恶意刷新实现代码
本质还是采用session方式进行时间比较,在单位时间内允许访问或者访问次数,如果有使用反向代理的话,也可以采用nginx配置 <?phpsession_start(); $k=$_GET[' ...
- 利用php做出简单的发布信息和回复功能
题目要求 1.建一个pinglun的数据库,自己建表2.完成一个简单的发布信息回复功能3.布局可以随便,主要是功能要实现4.注意回复是可以回复每一条的评论5.评论回复功能类似于qq空间的发布信息和回复 ...
- twisted学习之reactor
reactor是twisted框架里面一个很重要的抽象,它为我们实现了循环,所以我们不用再去实现循环了. reactor有如下特点: 1.reactor循环会一致运行下去,可以使用Ctrl+C或者相关 ...
- [leetcode-523-Continuous Subarray Sum]
Given a list of non-negative numbers and a target integer k, write a function to check if the array ...