首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >搭建日期和时间选择器

搭建日期和时间选择器
EN

Stack Overflow用户
提问于 2017-01-09 18:39:55
回答 1查看 798关注 0票数 2

当使用下面的属性搭建模型中的视图时,它会生成呈现浏览器日期选择器的代码,效果很好。

如何搭建一个生成日期和时间选择器的属性?

代码语言:javascript
复制
[Display(Name = "Date Start")]
[DataType(DataType.Date)]
public DateTime EventStart { get; set; }

我试过了,但它不起作用。

代码语言:javascript
复制
[DataType(DataType.DateTime)]
EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2017-01-09 19:25:59

您可以通过创建一个自定义的MVC并告诉EditorTemplate在[UIHint]中使用它来实现这一点。

ViewModel:

代码语言:javascript
复制
[Display(Name = "Date Start")]
[UIHint("DateTimePicker")]
public DateTime EventStart { get; set; }

Views/Shared/EditorTemplates/DateTimePicker.cshtml:

代码语言:javascript
复制
@model DateTime

<input type="text" name="@Html.NameFor(m => m)" id="@Html.IdFor(m => m)" value="@Model.ToString("o")"/>
<script type="text/javascript">
    // init the datepicker of your JS UI Framework (I am using jQuery UI here)
    $('#@Html.IdFor(m => m)').datepicker(); 
</script>

主视图中的用法:

代码语言:javascript
复制
@Html.EditorFor(m => m.EventStart)

这种方法的问题在于,您在EditorTemplate中创建的JS datepicker对象上失去了句柄。因此,如果您想要更改配置(例如,动态设置maxDate ),您必须构建额外的基础设施。

因此,我的建议是将JS datepicker直接附加到需要它的视图中,并在那里进行配置,而不是使用日期选择器的Editor模板。

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/41546103

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档