我有一个日期类型的文本框:
@Html.TextBoxFor(m => m.DateOfBirth, new { @class = "form-control", type = "date" })
模型字段 DateOfBirth 的
[Required]
[DataType(DataType.Date)]
public DateTime DateOfBirth { get; set; } // Дата рождения
但是日期格式是静态的mm/dd/yy,这对于俄语 ( dd/mm/yy ) 来说是错误的。当然我可以手动设置日期格式,但系统是多语言的,有英语以及俄语、吉尔吉斯语、乌兹别克语(它们都使用欧洲格式)。当用户更改语言时
Thread.CurrentThread.CurrentCulture =CultureInfo.CreateSpecificCulture(lang);
Thread.CurrentThread.CurrentUICulture = new CultureInfo(lang);
他应该看到适当的日期格式。但为什么它不会发生:(
我已经探索过格式取决于浏览器使用的语言。但是 chrome 不能用吉尔吉斯语显示...
您可以使用 jquery.ui 日期选择器完成您想要的操作。通过使用它(或任何其他提供类似功能的库),您可以轻松地跨多个浏览器维护一致的 UX,而使用标准的 HTML5 日期输入 ( <input type="date" />
),您将拥有特定于浏览器的行为。
您可以在加载页面时简单地将日期选择器设置为“区域”。似乎您的目标之一是能够处理多种语言,我建议坚持“本地化”的想法,而不仅仅是设置dateFormat
属性。如果 jquery ui 没有为您正在寻找的文化提供本地化,请创建一个。
我创建了一个简单的示例,您可以在其中查看本地化在客户端的工作情况。这个想法非常相似,但在您的情况下,它将在服务器端:https : //jsfiddle.net/ipvalverde/wxLxLe7p/9/
关于 ASP.net MVC,我建议您创建一个 Razor 视图,用您的文化信息在屏幕上设置所有日期选择器元素。像这样的东西:
@{
_Layout = null;
}
var currentCulture = System.Threading.Thread.CurrentThread.CurrentUICulture;
string cultureCode = currentCulture.Name;
string datepickerLocalization = // Convert the thread culture name to datepicker culture name...
<script>
$(function () {
$.datepicker.setDefaults($.datepicker.regional["@datepickerLocalization"]);
})
</script>
确保您已经加载了支持语言的本地化 javascripts。
如果这有帮助,请告诉我。
本文收集自互联网,转载请注明来源。
如有侵权,请联系[email protected] 删除。
我来说两句