繁体   English   中英

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

[英]Converting C# date-time function to Javascript

我有一个应用程序,我使用几个日期/时间操作函数来填充几个日历。 基本上,用户从下拉菜单(例如,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);
    }

您的代码中存在一些问题,例如:

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

你拿今天的月份是5,然后从你的选择中加上它的一些值,再添加1个,这就是要添加的很多monthes。

我认为您需要改变一些事情并按照以下方式执行此操作:将选择值更改为每月第一天的日期而不仅仅是数字:

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);
 }

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM