Warning: file_get_contents(/data/phpspider/zhask/data//catemap/9/javascript/442.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
C# 只有年的日期选择器_C#_Asp.net Mvc_Datetime_Datepicker_Bootstrap Datepicker - Fatal编程技术网

C# 只有年的日期选择器

C# 只有年的日期选择器,c#,asp.net-mvc,datetime,datepicker,bootstrap-datepicker,C#,Asp.net Mvc,Datetime,Datepicker,Bootstrap Datepicker,我正在尝试在asp.net-mvc项目中实现一个输入日期选择器,它只显示创建/编辑模型新值的年份。我希望日期和月份始终相同(31/12/年),并允许用户仅选择年份。大概是这样的: 在我的模型中,我有一个datetime字段: [Required] [DataType(DataType.Date)] [DisplayFormat(DataFormatString = "{0:yyyy-MM-dd}", ApplyFormatInEditMode = true)] public

我正在尝试在asp.net-mvc项目中实现一个输入日期选择器,它只显示创建/编辑模型新值的年份。我希望日期和月份始终相同(31/12/年),并允许用户仅选择年份。大概是这样的:

在我的模型中,我有一个datetime字段:

[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>
}
@使用(Html.BeginForm())
{
@Html.AntiForgeryToken()

@Html.ValidationSummary(true,“,new{@class=“text danger”}) @LabelFor(model=>model.MyDate,htmlAttributes:new{@class=“controllabel col-md-2”}) @EditorFor(model=>model.MyDate,new{htmlAttributes=new{@class=“form control”}) @Html.ValidationMessageFor(model=>model.MyDate,“,new{@class=“text danger”}) }
这是我的结果:


我需要该选择器只显示年份(也在编辑视图中),并保留固定的日期和月份(12/31)。有什么想法吗?

我想你需要从下拉列表中选择年份,而不是日期时间选择器。 你可以看到这个解


您可以使用,它将帮助用户在dropdownlist中搜索

如果您使用的是bootstrap datepicker,请尝试以下格式

minViewMode
您可以从这里查看文档:
你好@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", "Index", "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>&copy; @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>

如果我删除它,则显示日期选择器。但我不知道为什么,也不知道这是否会导致我在其他视图中出现其他错误。有没有办法将它们安全地结合在一起?

i如何创建一个
Hi。也许我需要一份清单。但该列表必须像日期选择器一样“自动”显示年份。也就是说,显示所有这些年,而不做自己的代码。像日期选择器一样显示所有年份。我以前没有看到过这一点,我建议您不要在这方面浪费时间,您可以使用下拉侧标签31/12/[year]Hi。我试着用胸环,但没用。它显示一个输入,但当我选择输入时,什么也没有显示。可能是因为样本不完整。我想一些类似的网址,但完整的例子。谢谢@Keras的工作,我现在试过了,而且这个样本很有效。请确保您添加了JQuery、bootstrap和bootstrap datepicker包或cdn以及样式表linksI copy粘贴了所有代码,但这些都不起作用。这是因为您所说的:“JQuery、引导和引导datepicker包或CDN和样式表链接”。我该怎么办?从nuget安装?或者只是在我的网站中复制一些css样式?
@Scripts.Render("~/bundles/jquery")