将值传回控制器时出现 ASP.NET MVC 日期时间区域性问题
我如何告诉我的控制器/模型解析日期时间时应该采用哪种文化?
我使用了一些这篇文章 将 jquery datepicker 实现到我的 mvc 应用程序中。
当我提交日期时,它会“在翻译中丢失”,我没有使用美国格式的日期,因此当它发送到我的控制器时,它只是变成空。
我有一个用户选择日期的表单:
@using (Html.BeginForm("List", "Meter", FormMethod.Get))
{
@Html.LabelFor(m => m.StartDate, "From:")
<div>@Html.EditorFor(m => m.StartDate)</div>
@Html.LabelFor(m => m.EndDate, "To:")
<div>@Html.EditorFor(m => m.EndDate)</div>
}
我为此制作了一个编辑模板,以实现 jquery datepicker:
@model DateTime
@Html.TextBox("", Model.ToString("dd-MM-yyyy"), new { @class = "date" })
然后我创建像这样的 datepicker 小部件。
$(document).ready(function () {
$('.date').datepicker({ dateFormat: "dd-mm-yy" });
});
这一切都运行良好。
这就是问题开始的地方,这是我的控制器:
[HttpGet]
public ActionResult List(DateTime? startDate = null, DateTime? endDate = null)
{
//This is where startDate and endDate becomes null if the dates dont have the expected formatting.
}
这就是为什么我想以某种方式告诉我的控制器它应该期望什么文化? 难道是我的模型不对?我可以以某种方式告诉它使用哪种文化,比如数据注释属性吗?
public class MeterViewModel {
[Required]
public DateTime StartDate { get; set; }
[Required]
public DateTime EndDate { get; set; }
}
编辑:此链接解释我的问题以及一个很好的解决方案。感谢格多隆
How can i tell my controller/model what kind of culture it should expect for parsing a datetime?
I was using some of this post to implement jquery datepicker into my mvc application.
When i submit the date it gets "lost in translation" i'm not using the US formatting for the date, so when it gets sent to my controller it simply becomes null.
I have a form where the user chooses a date:
@using (Html.BeginForm("List", "Meter", FormMethod.Get))
{
@Html.LabelFor(m => m.StartDate, "From:")
<div>@Html.EditorFor(m => m.StartDate)</div>
@Html.LabelFor(m => m.EndDate, "To:")
<div>@Html.EditorFor(m => m.EndDate)</div>
}
I've made an edit template for this, to implement the jquery datepicker:
@model DateTime
@Html.TextBox("", Model.ToString("dd-MM-yyyy"), new { @class = "date" })
I then create the datepicker widgets like this.
$(document).ready(function () {
$('.date').datepicker({ dateFormat: "dd-mm-yy" });
});
All this works fine.
Here is where the problems start, this is my controller:
[HttpGet]
public ActionResult List(DateTime? startDate = null, DateTime? endDate = null)
{
//This is where startDate and endDate becomes null if the dates dont have the expected formatting.
}
This is why i would like to somehow tell my controller what culture it should expect?
Is my model wrong? can i somehow tell it which culture to use, like with the data annotation attributes?
public class MeterViewModel {
[Required]
public DateTime StartDate { get; set; }
[Required]
public DateTime EndDate { get; set; }
}
Edit: this link explains my issue and a very good solution to it aswell. Thanks to gdoron
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论
评论(7)
您可以使用 IModelBinder 更改默认模型绑定器以使用用户区域性
并在 Global.Asax 中写入:
阅读更多信息 这个优秀的博客,描述了为什么 Mvc 框架团队向所有用户实施默认文化。
you can change the default model binder to use the user culture using IModelBinder
And in the Global.Asax write:
Read more at this excellent blog that describe why Mvc framework team implemented a default Culture to all users.
您可以创建 Binder 扩展来处理区域性格式的日期。
这是我编写的一个示例,用于处理 Decimal 类型的相同问题,希望您明白
更新
要使用它,只需像这样在 Global.asax 中声明绑定器
然后当模型绑定器必须做一些工作时,它会自动知道要做什么。
例如,这是一个包含一些十进制类型属性的模型的操作。我只是什么都不做
You can create a Binder extension to handle the date in the culture format.
This is a sample I wrote to handle the same problem with Decimal type, hope you get the idea
Update
To use it simply declare the binder in Global.asax like this
Then when the modelbinder has to do some work, it will know automatically what to do.
For example, this is an action with a model containing some properties of type decimal. I simply do nothing
出现此问题的原因是您在表单上使用 GET 方法。 MVC 中的 QueryString 值提供程序始终使用 Invariant/US 日期格式。请参阅:MVC DateTime 绑定日期格式不正确
解决方案有以下三种:
使用自定义绑定器始终将查询字符串日期视为 GB。如果您这样做,您必须确保所有日期都采用这种形式:
This issue arises because you are using the GET method on your Form. The QueryString Value Provider in MVC always uses Invariant/US date format. See: MVC DateTime binding with incorrect date format
There are three solutions:
Use a custom binder to always treat Query String dates as GB. If you do this you have to make sure that all dates are in that form:
提交日期时,您应始终尝试以“yyyy-MM-dd”格式提交。这将使其变得独立于文化。
我通常有一个隐藏字段以这种格式维护日期。使用 jQuery UI 的日期选择器这相对简单。
When submitting a date you should always try and submit it in the format "yyyy-MM-dd". This will allow for it to become culture independent.
I normally have a hidden field which maintains the date in this format. This is relatively simple using jQuery UI's datepicker.
为什么不简单地检查数据的文化并对其进行转换呢?这种简单的方法使我能够在模型中使用强类型日期,显示操作链接并在所需区域设置中编辑字段,而不必大惊小怪地将其绑定回强类型日期时间:
Why not simply inspect the culture of the data and convert it as such? This simple approach allowed me to use strongly typed dates in models, show action links and edit fields in the desired locale and not have to fuss at all binding it back into a strongly typed DateTime:
这对我有用
that did the trick for me
我有一个基于 @gdoron 的帖子的 MVC5 更新解决方案。如果其他人正在寻找这个,我会分享它。该类继承自
DefaultModelBinder
,并对无效日期进行异常处理。它还可以处理 null 值:就像 Global.Asax 中提到的示例一样,编写
ModelBinders.Binders.Add(typeof(DateTime), new DateTimeBinder());
ModelBinders.Binders.Add(typeof(DateTime?), new DateTimeBinder());
I have a updated solution for MVC5 based on the Post of @gdoron. I will share it in case anyone else is looking for this. The class inherits from
DefaultModelBinder
and has exception handling for invalid dates. It also can handle null values:And just like the mentioned sample in the
Global.Asax
writeModelBinders.Binders.Add(typeof(DateTime), new DateTimeBinder());
ModelBinders.Binders.Add(typeof(DateTime?), new DateTimeBinder());