FullCalendarDemo5 控件的实例讲解—拖拽实现值班排班(二)

发布于:2023-02-01 ⋅ 阅读:(738) ⋅ 点赞:(0)

FullCalendarDemo5 控件的实例讲解—拖拽实现值班排班

(二)c# asp.net 操作FullCalendarDemo5连接数据库

环境:SQL 2008 +VS2012

1.首先创建数据库:

两个表Users和dutyplay

Users:

dutyplay:

 

 这里有几个字段是多余的,实际项目中需要,Demo中不是全部需要。

在Users表里创建几个用户:

2.创建WEB工程:

在VS2012中,新建工程,创建代码如下:

引入FullCalendar插件

    <link href="./assets/main.min.css" rel="stylesheet"/>

    <script src="./assets/main.min.js"></script>

    <script src="./assets/jquery.min.js"></script>

    <script src="./assets/locales/zh-cn.js"></script>

拖拽对象部分,是绑定了数据库的所有用户名,也就是所谓的值班员

    <div style="float:left;">

        

         <div id="duty-config" style="/*width:880px;*/height:703px;overflow:auto;">

             <div id='wrap'>

                 <div id='external-events' style="margin-left: 300px;">

                    <h4 style="text-align:center;">值班员</h4>

                

                      <asp:Repeater ID="Repeater1" runat="server" DataSourceID="SqlDataSource1">

                             <ItemTemplate>

                                     <div class='fc-event fc-h-event fc-daygrid-event fc-daygrid-block-event'><div class='fc-event-main'><%# Eval("UserName") %></div>                                  </div>

                             </ItemTemplate>

                       </asp:Repeater>

                     <p style="text-align:center">拖拽即保存<br />单击即删除</p>

                  

               </div>                  

           </div>

         </div>

    </div>

写入显示FullCalendar日历的地方:

<!-- FullCalendar 对象开始 -->

    <div id='calendar-container'>

      <div id='calendar'></div>

    </div>

<!-- FullCalendar 对象结束 -->

配置调用FullCalendar的执行脚本:

document.addEventListener('DOMContentLoaded', function () {

            var Calendar = FullCalendar.Calendar;           

            var containerEl = document.getElementById('external-events');

            var calendarEl = document.getElementById('calendar');

var calendar = new Calendar(calendarEl, {

                headerToolbar: {

                    left: 'prev,next today',

                    center: 'title',

                    right: 'dayGridMonth,timeGridWeek,timeGridDay'

                },

                locale: 'zh-cn', //指定中文

                editable: true,

                eventOrder: 'order',//排序

                events: [<%=jsonstr_start %>] //显示的值班表数据

            });

            calendar.render();

        });

上面的脚本里面,使用jsonstr_start全局变量来接收已经排好的值班表数据,格式为JSON格式,示例如:

[{title:'刘德华',order:'1',start:'2022-08-01'},{title:'易烊千玺',order:'2',start:'2022-08-01'},{title:'刘亦菲',order:'3',start:'2022-08-02'},{title:'易烊千玺',order:'4',start:'2022-08-02'},{title:'郭富城',order:'5',start:'2022-08-03'},{title:'王祖贤',order:'6',start:'2022-08-03'}]

代码页面,从数据库获取用户已排好的值班表:

protected string jsonstr_start = "";//值班表数据变量

private void Get_Dutydata()

        {

            DBHelp db = new DBHelp();

            string sqlstrstart = "SELECT dt.id,dt.dutydate,us.UserName  FROM dutyplay as dt,Users as us  where dt.userid=us.userid order by duty_time asc";

            DataSet dsstart = db.GetDataSets(sqlstrstart);

            int data_count = dsstart.Tables[0].Rows.Count;

            if (data_count != 0)

            {

                for (int i = 0; i < data_count; i++)

                {

                    string tmp = "{title:" + "'" + dsstart.Tables[0].Rows[i]["UserName"].ToString() + "'," + "order:'" + (i + 1) + "',start:'" + DateTime.Parse(dsstart.Tables[0].Rows[i][1].ToString()).ToString("yyyy-MM-dd") + "'}";//order属性用于指定排序

                    if (i != (data_count - 1))

                    {

                        jsonstr_start += tmp + ",";

                    }

                    else

                    {

                        jsonstr_start += tmp;

                    }

                }

            }

        }

以上,就完成了值班数据的显示功能。

开发过程中的几个疑问:

(1)怎么实现日历的第一位是周一,而不是默认的周日?

插件默认是如下界面,第一位是SUN,而不是MON。其实这是英文版,改成中文版,第一位就是周一了。老版本里语言设置参数是lang:’zh-cn’。

 (2)项目中,要求有代班员和值班员区分,一般代班员在上,值班员在下,怎么实现排序?

FullCalendar版本获取的人名排序默认是按照人名拼音的首字母大小进行排序,所以刘亦菲会一直显示王祖贤的前面。要实现指定的排序,通过eventOrder参数来实现,配置参数为order,然后在数据获取的时候,指定自定义顺序的order值即可。该参数默认值是title,在FullCalendar v2.4.0版本下需要编写自定义函数,函数里配置排序规则,FullCalendar v5.11.2 版本下,直接指定 eventOrder: 'order'就可以。