将C#日期时间函数转换为Javascript

时间:2019-05-12 18:00:37

标签: javascript c# datetime

我有一个应用程序,其中使用了几个日期/时间操作功能来填充几个日历。基本上,用户从下拉列表中选择一个月/年(例如2019年3月),然后我在日历中填充03/01/2019和03/31/2019。

我想做这个客户端,所以试图将那些函数转换为javascript,结果却很奇怪,看不到我在做什么错。

这是我定义和使用的原始C#函数:

public static DateTime FirstDayOfMonth(this DateTime dt)
{
    return new DateTime(dt.Year, dt.Month, 1);
}

public static DateTime LastDayOfMonth(this DateTime dt)
{
    DateTime dtFirstDayOfMonth = new DateTime(dt.Year, dt.Month, 1);
    DateTime dtLastDayOfMonth = dtFirstDayOfMonth.AddMonths(1).AddDays(-1);
    return dtLastDayOfMonth;
}

我这样称呼这些:

DateTime dtSelected = DateTime.Today.AddMonths(int.Parse(ddlMonth.SelectedValue)).AddYears(-1);
dtStartDate = Utils.FirstDayOfMonth(dtSelected);
dtEndDate = Utils.LastDayOfMonth(dtSelected);

下拉列表的填充方式如下:

for (int i = 12; i >= 1; i--)
{
    string s = DateTime.Now.AddYears(-1).AddMonths(i).ToString("Y");
    ListItem li = new ListItem(s, i.ToString());
    ddlMonth.Items.Add(li);
}

下拉菜单如下:

May, 2019    -- value of 12
April, 2019  -- value of 11
....
July, 2018   -- value of 2
June, 2018   -- value of 1

这是我尝试翻译成Javacript的尝试:

function firstDayOfMonth(dt) {debugger
    var year = dt.getFullYear();
    var month = dt.getMonth();
    var day = dt.getDate();
    return new Date(year, month, 1);
}

function lastDayOfMonth(dt) {debugger
    var year = dt.getFullYear();
    var month = dt.getMonth();
    var day = dt.getDate();
    var firstDayOfMonth = new Date(year, month, 1);
    var lastDayOfMonth = firstDayOfMonth.AddMonths(1).AddDays(-1); --> shows error when called; Object doesn't support property or method 'AddMonths'

    return lastDayOfMonth;
}

$(document).on('change', '#ddlMonth', function () {debugger
    var monthID = this.value;
    var ddlMonth = $('#ddlMonth');
    var today = new Date();
    var startDate = new Date();
    var endDate = new Date();
    var dtSelected = new Date();

    if (ddlMonth.val() == "")
    {
        ....
    }
    else
    {debugger
        dtSelected.setMonth(dtSelected.getMonth() + ddlMonth.val() + 1); -- this becomes "Wed Oct 12, 2360" if I select "March, 2019" from dropdown!
        dtSelected.setFullYear(dtSelected.getFullYear() - 1);
        dtStartDate = firstDayOfMonth(dtSelected);
        dtEndDate = lastDayOfMonth(dtSelected);
    }

1 个答案:

答案 0 :(得分:0)

您的代码有问题,例如:

dtSelected.setMonth(dtSelected.getMonth() + ddlMonth.val() + 1); -- this becomes August of 2036!

您将今天的月份取为5,然后从您的选择中将其添加到某些值,再加上1,这将增加很多个月。

我认为您需要进行一些更改,例如: 将选择值更改为每个月第一天的日期,而不仅仅是数字:

for (int i = 12; i >= 1; i--)
{
    DateTime date = DateTime.Now.AddYears(-1).AddMonths(i);
    ListItem li = new ListItem(date.ToString("Y"), date.ToString("yyyy-MM-01"));
    ddlMonth.Items.Add(li);
}

以这种格式,您可以毫无问题地在js上使用它。

现在使用您的js函数:

function lastDayOfMonth(dt) {debugger
    var year = dt.getFullYear();
    var month = dt.getMonth();
    var day = dt.getDate();
    var lastDayOfMonth = new Date(year, month, 1);
    lastDayOfMonth.setMonth(lastDayOfMonth.getMonth() + 1);
    lastDayOfMonth.setDate(lastDayOfMonth.getDate() - 1);

    return lastDayOfMonth;
}

$(document).on('change', '#ddlMonth', function () {debugger
    var ddlMonth = $('#ddlMonth');
    dtStartDate = new Date(ddlMonth.val());
    dtEndDate = lastDayOfMonth(dtStartDate);
 }