使用 MomentJS 从 JavaScript 发布到 C# 时的日期解析问题



我在JS和C#(asp.net 核心2.1(中的日期中遇到了一个奇怪的问题。我在前端添加日期,并尝试使用以下 JavaScript 将它们发布回服务器:

$("#editOperation").on("submit",
function(e) {
e.preventDefault();
var form = $(this);
var url = form.attr("action");
// change date to YYYY-MM-DD format
for (let i = 0; i < form[0].length; i++) {
if (form[0][i].className.includes("hdn-exclude-")) {
if (form[0][i].value) {
var date = moment(form[0][i].value);
form[0][i].value = date.format('YYYY-MM-DD');
}
}
}
var formData = new FormData(form.get(0));
$.ajax({
url: url,
data: formData,
type: "post",
contentType: false,
processData: false,
success: function (response) {
if (response.result) {
toastr.success("Success!");
setTimeout(function () {
window.location = $("#cancelEditOperation").attr("href");
},
1000);
} else {
toastr.error(response.errorMessage);
}
}
});
});

但是,我遇到的问题是,当日期超过任何给定月份的 12 日(例如13/07/2018- 澳大利亚格式(时,C# 似乎无法解析它并为其提供默认值1/01/0001 12:00:00 AM

如果日期的日期在任何给定月份(例如 12/06/2018(之前或 12 日,则在 C# 端是正确的6/12/2018 12:00:00 AM

这是我在 C# 中的模型:

public class GetOperationExcludeDate
{
public DateTime StartDate { get; set; }
public DateTime EndDate { get; set; }
}

和我的行动:

[HttpPost("EditOperation/{id}")]
[AutoValidateAntiforgeryToken]
public async Task<ApiBooleanResponse> EditOperation(string id, GetOperationExcludeDate model)
{
return await _transportCompanyService.EditServiceOperationAsync(id, model);
}

如何规范化日期,以便 C# 根据区域识别格式并正确解析它?(我可以看到,当给定澳大利亚格式时,它试图将其解析为美国格式(

以 ISO 8601 格式发送您的日期。

使用 JavascriptDate对象,您可以:

var isoDate = myDate.toISOString(); // returns "2018-06-12T01:58:40.867Z"

或使用时刻:

var isoDate = momentDate.format(); // returns "2018-06-12T10:58:40+09:00"

最新更新