如何根据来自网络服务

时间:2017-12-06 01:08:21

标签: jquery ajax web-services jquery-ui jquery-ui-datepicker

在我的项目中,有很多员工,每个人每周都有自己的日程安排,我已经实现了一个Web服务,它返回一个整数列表,代表指定员工的工作日,这是所有人的主要想法。这是因为我需要阻止用户在一周的其他日子进行约会..如何隐藏日期选择器中的那些日子?或者如果还有其他方法可以做到这一点?

网络服务

[WebMethod]

    public void getWorkDays(int id)
    {
        WorkDays wd = new WorkDays(id);

        List<Days> workDays = new List<Days>();
        String docSch_query = "select * from workDays where empId = " + id + " and status=1";
        DBConnect conn = new DBConnect();
        DataTable dt = conn.select(docSch_query);

        foreach (DataRow r in dt.Rows)
        {
            switch (r["dayId"].ToString())
            {
                case "1":
                    workDays.Add(new Days(1,"sat"));
                    break;
                case "2":
                    workDays.Add(new Days(2, "sun"));
                    break;
                case "3":
                    workDays.Add(new Days(3, "mon"));
                    break;
                case "4":
                    workDays.Add(new Days(4, "tus"));
                    break;
                case "5":
                    workDays.Add(new Days(5, "wed"));
                    break;
                case "6":
                    workDays.Add(new Days(6, "thu"));
                    break;
            } 
        }

        JavaScriptSerializer js = new JavaScriptSerializer();
        Context.Response.Write(js.Serialize(workDays));           
    }

日期选择器

$(document).ready(function () {

        var dates=$.ajax({
            type: "POST",
            url: "getdays.asmx/getWorkDays",
            data: {id:<%#int.Parse(Session["appWith"].ToString())%>},
            dataType: "json",

            success: function (data) {

                return data.d;
            }
        });

        $('#edob').datepicker({

            firstDay: 3,
            beforeShowDay: function (date) {
                var available = $.inArray(date.getDay(), dates['int']) > -1;

                if (available) {
                    return [1];   //return available date
                }
                else {
                    return [0];   //return not available
                }
            }
        });
    })

1 个答案:

答案 0 :(得分:0)

我找到了问题的解决方案..

$(document).ready(function () {
        var dates = $.parseJSON(
            $.ajax({
                type: "POST",
                url: "getdays.asmx/getWorkDays",
                data: { id: <%=int.Parse(Session["appWith"].ToString())%> },
                dataType: "json",
                async: false
            }).responseText);

        $('#edob').datepicker({

            firstDay: 3,
            beforeShowDay: function (date) {
                var a =[];
                var weekend = false;
                for (i = 0; i < dates.length; i++) {
                    a.push(dates[i].Id);
                }
                var weekend = date.getDay() == 5 || date.getDay() == 6 || !($.inArray(date.getDay(),a)>-1);
                return [!weekend, weekend ? 'myweekend' : ''];
            }
      });
    });