javascript - 保存输入字段文本显示在 Bootstrap 日期选择器上

标签 javascript jquery datepicker

我有一个 ASP.net MVC4 项目,其中引导日期选择器最近停止在 Chrome 中按预期工作,但它们在 IE 中工作正常。

这张图片显示了我遇到的问题。

DatePicker

我的 bundleconfig 如下所示:

            bundles.Add(new ScriptBundle("~/bundles/jquery").Include(
                    "~/Scripts/jquery-1.12.4.js",
                    "~/Scripts/jquery-ui-1.12.1.js"
                    )
                    );


        bundles.Add(new ScriptBundle("~/bundles/createTimeRequest").Include(
                    "~/Scripts/createTimeRequest.js"));

        bundles.Add(new ScriptBundle("~/bundles/jqueryval").Include(
                    "~/Scripts/jquery.validate*"));

        bundles.Add(new ScriptBundle("~/bundles/moment").Include(
                    "~/Scripts/moment.js"));

        bundles.Add(new ScriptBundle("~/bundles/Calendar").Include(
                                "~/Scripts/fullcalendar.js"));

        // Use the development version of Modernizr to develop with and learn from. Then, when you're
        // ready for production, use the build tool at http://modernizr.com to pick only the tests you need.
        bundles.Add(new ScriptBundle("~/bundles/modernizr").Include(
                    "~/Scripts/modernizr-*"));

        bundles.Add(new ScriptBundle("~/bundles/bootstrap").Include(
                  "~/Scripts/bootstrap.js",
                  "~/Scripts/jquery.dataTables.js",
                  "~/Scripts/dataTables.jqueryui.js",
                  "~/Scripts/dataTables.foundation.js",
                  "~/Scripts/dataTables.bootstrap.js",
                  "~/Scripts/dataTables.buttons.min.js",
                  "~/Scripts/bootstrap-datepicker.js",
                  "~/Scripts/buttons.print.min.js",
                  "~/Scripts/respond.js"));

        bundles.Add(new StyleBundle("~/Content/css").Include(
                   "~/Content/themes/base/jquery.ui.all.css",
                   "~/Content/themes/base/jquery.ui.base.css",
                   "~/Content/themes/base/jquery.ui.theme.css",
                   "~/Content/dataTables.bootstrap.css",
                   "~/Content/jquery.dataTables.css",
                   "~/Content/dataTables.foundation.css",
                   "~/Content/dataTables.jqueryui.css",
                   "~/Content/bootstrap.css",
                   "~/Content/bootstrap-datepicker.css",
                  // "~/Content/themes/base/datepicker.css",
                   "~/Content/fullcalendar.css",
                   "~/Content/site.css",
                   "~/Content/buttons.dataTables.min.css"
                  ));

通过类引用告诉输入字段是日期选择器的 javascript 文件如下所示:

var year = (new Date).getFullYear();
$(function () {
    $('.datepicker').datepicker({
        orientation: "right",
        startDate: new Date(year, 0, 1),
        //endDate: new Date(year, 11, 31)
    });

    $('.dpManager').datepicker({
        orientation: "right",
        endDate: '+365d'
    });

})

View 中的razor语法如下:

  <div class="col-md-4"><label>Select company: </label>@Html.ListBox("Company", (MultiSelectList)ViewBag.Company, new { @class = "form-control", size = 9 })</div>
        <div class="col-md-4">
                @Html.Label("Start Date:")
                @Html.Editor("sDateTime", new { htmlAttributes = new { @class = "dpManager form-control" } })

        </div>
        <div class="col-md-4">
                @Html.Label("End Date:")
                @Html.Editor("eDateTime", new { htmlAttributes = new { @class = "dpManager form-control" } })
            </div>
        </div>
@section Scripts {
    @Scripts.Render("~/bundles/jqueryval")
    @Scripts.Render("~/bundles/createTimeRequest")
}
<script>
        if (!$("#sDateTime").val() || !$("#sDateTime").val()) {
            $('#btnSubmit').prop("disabled", true);
        }
</script>

这是我的布局文件:

<head>
    <meta charset="utf-8" />
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>@ViewBag.Title</title>
    <meta http-equiv="X-UA-Compatible" content="IE=edge" />
    @Styles.Render("~/Content/css")
    @Scripts.Render("~/bundles/modernizr")


</head>
<body>
   ........
    @Scripts.Render("~/bundles/jquery")
    @Scripts.Render("~/bundles/bootstrap")
    @RenderSection("scripts", required: false)
</body>

这只是本周发生的,也许 chrome 推出了新的更新?您可以看到日期选择器正在显示,但无论出于何种原因,保存的输入都优先。我尝试更新我的 jquery 和 jquery ui。我唯一没有尝试的是更新 Bootstrap 。不确定我是否想尝试一下并破坏其他东西。

非常感谢任何帮助。

最佳答案

我建议你使用 autocomplete=off

<input autocomplete=off />

How do you disable browser Autocomplete on web form field / input tag?

关于javascript - 保存输入字段文本显示在 Bootstrap 日期选择器上,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/50766655/

相关文章:

javascript - 传单标记禁用悬停或悬停时不显示任何内容

jquery - 单击切换 div 后使 jquery 按钮不可见

java - 如何自定义android默认类(datepicker,numpicker等)

javascript - 将 .txt 而不是图像文件加载到 jquery 中

javascript - 如何在 React 中将我的子组件移动到新的父组件?

javascript - selenium IDE 不删除属性 "readonly"

javascript - 获取与选中的输入框处于同一级别的元素

javascript - Datepicker打开有些问题

php - 为什么这个 javascript/jQuery JSON 解析代码不起作用?

javascript - 在另一个函数中使用此实例访问用户密码变量