如何解决只有年份的日期选择器
我正在尝试在我的 asp.net-mvc 项目中实现一个输入日期选择器,它只显示创建/编辑模型新值的年份。我希望日期和月份始终相同(31/12/year)并允许用户仅选择年份。像这样:
在我的模型中,我有这个日期时间字段:
[required]
[DataType(DataType.Date)]
[displayFormat(DataFormatString = "{0:yyyy-MM-dd}",ApplyFormatInEditMode = true)]
public System.DateTime MyDate{ get; set; }
我试过“{0:yyyy-31-12}”,但没有用。
这是创建视图:
@using (Html.BeginForm())
{
@Html.AntiForgeryToken()
<div class="form-horizontal">
<hr />
@Html.ValidationSummary(true,"",new { @class = "text-danger" })
<div class="form-group">
@Html.LabelFor(model => model.MyDate,htmlAttributes: new { @class = "control-label col-md-2" })
<div class="col-md-10">
@Html.EditorFor(model => model.MyDate,new { htmlAttributes = new { @class = "form-control" } })
@Html.ValidationMessageFor(model => model.MyDate,new { @class = "text-danger" })
</div>
</div>
<div class="form-group">
<div class="col-md-offset-2 col-md-10">
<input type="submit" value="Create" class="btn btn-default" />
</div>
</div>
</div>
}
这是我的结果:
我需要该选择器仅显示年份(也在编辑视图中)并保留固定的日期和月份 (12/31)。有什么想法吗?
解决方法
我认为您需要下拉年份列表而不是日期时间选择器。 你可以看到这个解决方案 Month and Year drop down list for ASP.NET mvc。
你可以使用select2 plugin,它会帮助用户在下拉列表中搜索
,如果您使用的是 bootstrap-datepicker,请尝试以下格式。
geog
您可以从这里查看文档: bootstrap-datepicker
,你好@M Arif Sarıkaya。
我找到了它不起作用的原因。 这是因为_layout.cshtml:
<!DOCTYPE html>
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8"/>
<meta charset="utf-8" />
<meta name="viewport" content="width=device-width,initial-scale=1.0">
<title>@ViewBag.Title - Mi aplicación ASP.NET</title>
@Styles.Render("~/Content/css")
@Scripts.Render("~/bundles/modernizr")
</head>
<body>
<div class="navbar navbar-inverse navbar-fixed-top">
<div class="container">
<div class="navbar-header">
<button type="button" class="navbar-toggle" data-toggle="collapse" data-target=".navbar-collapse">
<span class="icon-bar"></span>
<span class="icon-bar"></span>
<span class="icon-bar"></span>
</button>
@Html.ActionLink("Nombre de la aplicación","Index","Home",new { area = "" },new { @class = "navbar-brand" })
</div>
<div class="navbar-collapse collapse">
<ul class="nav navbar-nav">
<li>@Html.ActionLink("Inicio","Home")</li>
<li>@Html.ActionLink("Acerca de","About","Home")</li>
<li>@Html.ActionLink("Contacto","Contact","Home")</li>
</ul>
</div>
</div>
</div>
<div class="container body-content">
@RenderBody()
<hr />
<footer>
<p>© @DateTime.Now.Year - Mi aplicación ASP.NET</p>
</footer>
</div>
@Scripts.Render("~/bundles/jquery")
@Scripts.Render("~/bundles/bootstrap")
@RenderSection("scripts",required: false)
</body>
</html>
这部分导致了错误:
@Scripts.Render("~/bundles/jquery")
如果我删除它,则显示日期选择器。但我不知道为什么以及这是否会导致我在其余视图中出现其他错误。有没有办法安全地组合它们?
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。