我从asp.net web api发送日期,如下所示:
SubmitDate.ToString()
它正在返回:
12/13/2018 8:24:20 AM
在角度组件和我使用角管显示“2018年12月12日”格式的日期,它与我当前的PC日期格式工作正常,但当我更改我的电脑的日期格式,它给我错误,如下所示
'Unable to convert "18/12/13 1:54:20 PM" into a date' for pipe 'DatePipe'
请帮助理解它,我尝试过这些方法
SubmitDate.ToLocalTime().ToString()
SubmitDate.ToUniversalTime().ToString()
但没有成功。如何从web api传递和处理日期到角度组件?
带角管:
solution.SubmitDate | date:'MMMM d, yyyy'
您可以使用DateTime.ToString()重载,它接受一个参数以允许您格式化日期。
例如,要格式化为此时适合您的日期,您可以使用:
var date = new DateTime(2018, 12, 13, 8, 24, 20);
Console.WriteLine(date.ToString("MM/dd/yyyy h:mm:ss tt", CultureInfo.InvariantCulture));
//12/13/2018 8:24:20 AM
此处使用CultureInfo.InvariantCulture不考虑任何特定于文化的格式/本地化。
有关日期格式的更多文档 - https://docs.microsoft.com/en-us/dotnet/standard/base-types/custom-date-and-time-format-strings
Javascript有一个日期对象。如果您将日期作为可接受的格式发送,您可以自动将其解析为javascript日期对象。
声明这样的响应接口以进行自动解析。
export interface something {
time: Date;
}
从asp.net你需要确保你发送一个javascript理解的格式。从docs接受的格式可能如下所示:
December 17, 1995 03:24:00
要么
1995-12-17T03:24:00
问题是asp.net和javascript对日期格式有不同的标准。
如果你想制作一个客户端解决方案[JavaScript]:
function ToJavaScriptDate(value) {
var pattern = /Date\(([^)]+)\)/;
var results = pattern.exec(value);
var dt = new Date(parseFloat(results[1]));
return (dt.getMonth() + 1) + "/" + dt.getDate() + "/" + dt.getFullYear();
}
但最好的方法是服务器端解决方案。这是一个返回真实UTC时间[C#]的函数。
return DateTime.UtcNow
.Subtract(new DateTime(1970,1,1,0,0,0,DateTimeKind.Utc))
.TotalMilliseconds;
这样你就可以确切地知道客户端的含义。时间可能因客户而异。
您可以在API端SubmitDate.ToString("MMM d, yyyy");
修复日期的格式
请试试这个。它对我有用。
var utcDate1 = new Date(Date.UTC(96,1,2,3,4,5)); //预期产出:周五,1996年2月2日03:04:05 GMT