ASP.NET MVC (Razor)开发
过去我们使用过一些周报工具来完成项目组或部门的周报填写与考核工作,但多少有些不理想,要么功能太过简单,要么功能特别繁杂,不接地气,使用不便。
后来我们就考虑自己开发一个简单的,实用的,易用的,接地气的周报填报考核系统。
一开始预想比较简单,就是些简单的增删改查,但是做下来会发现,把一件产品做好,不管他是简单是复杂,想要做好,都是需要投入巨大的时间和精力的。
技术选型:
ASP.NET MVC + Razor 视图引擎,jQuery,数据库 SQL Server 2008 R2
微软企业库
数据访问层使用了自有ORM解决方案
表结构设计:
除了基本的组织机构,角色,人员,权限这些表以外,周报的表使用了一对多的两张关进行关联,一张主表用于存储周报主要信息,子表用于存储周报的内容条目,也就是说一个周报,是多条数据组织汇总起来的。
为了方便对数据的统计分析和查询,周报表中对周次,日期,年月等做了冗余。
使用 ASP.NET MVC Razor 来开发 WEB 画面,非常的简单高效,只要在视图顶部声明视图所使用的模型类,就可以在此视图中直接访问模型类实例中的数据。
在 JavaScript 脚本中访问模型中的数据:
使用 Razor 语法输出HTML
使用 Razor 视图引擎开发WEB应用的生产性非常的高,代码可读性好,结构工整。
此外,周报系统一个通用的底层功能就是对周次的计算,直接贴出代码如下:
/// <summary> /// 获取指定日期,在为一年中为第几周 /// </summary> /// <param name="dt">指定时间</param> /// <reutrn>返回第几周</reutrn> public static int GetWeekOfYear(DateTime dt) { GregorianCalendar gc = new GregorianCalendar(); int weekOfYear = gc.GetWeekOfYear(dt, CalendarWeekRule.FirstDay, DayOfWeek.Monday); return weekOfYear; } /// <summary> /// 获取指定日期为当月的第几周 /// </summary> /// <param name="dt"></param> /// <param name="weekStart"></param> /// <returns></returns> public static int GetWeekOfMonth(DateTime dt) { int weekStart = 1; //WeekStart //1表示 周一至周日 为一周 //2表示 周日至周六 为一周 DateTime FirstofMonth; FirstofMonth = Convert.ToDateTime(dt.Date.Year + "-" + dt.Date.Month + "-" + 1); int i = (int)FirstofMonth.Date.DayOfWeek; if (i == 0) { i = 7; } if (weekStart == 1) { return (dt.Date.Day + i - 2) / 7 + 1; } if (weekStart == 2) { return (dt.Date.Day + i - 1) / 7; } return 0; //错误返回值0 } /// <summary> /// 计算本周起始日期(礼拜一的日期) /// </summary> /// <param name="someDate">该周中任意一天</param> /// <returns>返回礼拜一日期,后面的具体时、分、秒和传入值相等</returns> public static DateTime CalculateFirstDateOfWeek(DateTime someDate) { int i = someDate.DayOfWeek - DayOfWeek.Monday; if (i == -1) i = 6;// i值 > = 0 ,因为枚举原因,Sunday排在最前,此时Sunday-Monday=-1,必须+7=6。 TimeSpan ts = new TimeSpan(i, 0, 0, 0); return someDate.Subtract(ts); } /// <summary> /// 计算本周结束日期(礼拜日的日期) /// </summary> /// <param name="someDate">该周中任意一天</param> /// <returns>返回礼拜日日期,后面的具体时、分、秒和传入值相等</returns> public static DateTime CalculateLastDateOfWeek(DateTime someDate) { int i = someDate.DayOfWeek - DayOfWeek.Sunday; if (i != 0) i = 7 - i;// 因为枚举原因,Sunday排在最前,相减间隔要被7减。 TimeSpan ts = new TimeSpan(i, 0, 0, 0); return someDate.Add(ts); }
最终完成功能与效果:
一:周报的填写;
1)周报中的“工作类型”、“工作任务”、“完成情况”作为基础数据*配置;
2)“工作类型”、“工作任务”只需简单设置名称即可,无需繁杂的参与人负责人进度时间等数据,术业有专攻,这部分工作交给项目管理软件处理,此外,周报与绩效考核的使用场景不单单是项目研发,行管团队或传统企业一般不需要有“项目”的概念,只需一个工作分类即可。
3)可按组织机构或按个人对周报进行查询;
二:考核功能
1)可*设置人员之间的考核关系,不和组织机构绑定,因为多数时候项目领导或部门领导都不会直接考核每一个人,另外也存在人员临时借调的情况,与组织机构并不一定完全一致;
2)考核项可*配置,可根据自身需求自行添加要考核的项,如工作完成情况,工作质量,是否加班等,考核结果可设置分值,用于绩效统计;
三:统计
1)根据指定的时间段,对指定组织机构中的人员经过考核的周报进行汇总,并将考核得分累计排名,人员的工作绩效情况一目了然。
四:其它
完整的组织机构管理,人员管理,角色权限管理功能,可在此基础上继续开发。
截图:
填写周报:
注意,填写周报前,需要到“设置”下的“周报”中,添加工作类型,工作任务等基础数据。
如果该周报经过审核,则不再允许修改,并显示审核结果。
按组织机构查询:
按个人查询:
考核:
支持考核与撤销考核,考核之后该周报不再允许修改,撤销考核后填写人可以再次修改周报。
注意:图中的“完成质量”、“完成情况”、“工作状态”、“加班”这些考核项目,是在“设置”下的“周报”中自行定义的。
统计:
统计中的得分项目是根据考核项生成的,而考核项允许自定义。
设置工作类型/任务
设置考核项目
设置考核关系
分配角色与权限