- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我有以下代码:
$('#MilestoneStartDate').datepicker({
dateFormat: 'dd M yy'
});
如果您使用鼠标单击弹出窗口中的日期来输入日期,则一切正常,但如果有人以与上述不同的格式输入日期或将日期粘贴到文本框中(例如“1/1/2016”),当我有这个代码时:
var startDate = $('#MilestoneStartDate').datepicker("getDate");
startDate 变量显示为当前日期(即使显然 1/1/2016 不是当前日期)
处理这些情况的最佳方法是什么?我应该阻止人们输入和粘贴日期还是有办法进行格式转换?
最佳答案
getDate datepicker 方法返回日期类型,而不是字符串。
您需要使用日期格式将返回值格式化为字符串。使用日期选择器的formatDate函数:
var startDate = $('#MilestoneStartDate').datepicker('getDate');
$.datepicker.formatDate('dd M yy', startDate);
格式说明符的完整列表为 available here .
编辑
$('#MilestoneStartDate').datepicker("getDate");
如果通过鼠标选择日期并单击日期弹出窗口,则始终为您提供正确的日期,但如果有人以不同格式手动书写或粘贴日期,则这将为您提供当前日期。
因此,要处理这种情况,请使用以下代码。
$(function(){
$('#MilestoneStartDate').datepicker({
dateFormat: 'dd M yy'
});
});
var strSelectedDate = new Date($('#MilestoneStartDate').val());
var formatedDate = $.datepicker.formatDate('dd M yy', strSelectedDate);
alert(formatedDate);
根据 @Boris Serebrov 评论
关键是 new Date($('#MilestoneStartDate').val()) - 它实际上试图“猜测”格式,所以像“2 Mar 2016”、“March 2 2016”或“2016, 2 March”将被正确解析。
一步一步:
情况1:
这里strSelectedDate
为您提供标准格式的日期,假设我从它给出的日期弹出窗口中选择02 Mar 2016
Wed Mar 02 2016 00:00:00 GMT+0530
现在
$.datepicker.formatDate('dd M yy', strSelectedDate);
给你格式的日期,如下所示
02 Mar 2016
案例:2
正如您在问题中提到的,如果用户手动输入日期(例如 1/1/2016 strSelectedDate
),则会为您提供如下所示的标准日期
Fri Jan 01 2016 00:00:00 GMT+0530
然后
$.datepicker.formatDate('dd M yy', strSelectedDate);
给你格式化的日期
01 Jan 2016
这是预期的正确日期。
情况3:
现在,如果用户手动写入一些无效日期,例如112016
,则strSelectedDate
返回无效日期
,因此您可以在这里实现一些客户端验证用户输入正确的日期。
希望这对您有帮助。
关于jquery - 使用jquery datepicker时,处理人们以不同格式输入日期的正确方法是什么?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/35552177/
我正在尝试使用 720Kb 日期选择器。 https://github.com/720kb/angular-datepicker 使用简单示例时: 我收到打击错误: angular.js:1
我开始使用react-datepicker组件。 https://github.com/Hacker0x01/react-datepicker 我运行了该示例,现在我想对其进行调整,使其没有初始值。示
我正在使用 Angular-ui 日期选择器,除了日期选择器的初始状态外,一切实际上都工作正常。我选择日期后,看起来不错。见下文: 初始状态 在选择器中选择日期后 所以,显然我在第一种情况下得到了日期
我需要为回历日期设置日期选择器。我可以使用 jquery datepicker 或 bootstrap datepicker。但是我写了这段代码
在选择范围时,我遇到了 jquery UI datepicker 的一个奇怪问题。在提出问题之前,我正在研究许多其他人编写的代码。他们以优化的顺序包含了 jquery 工具和 UI,因此所有功能都可以
我有两个剑道 DatePickers 来选择工作的开始和结束日期。作业由多个任务组成,其中包含自己的完成日期(任务在网格中列出,每条记录使用 kendo DatePicker 选择完成日期) 当用户设
我想将功能添加到 Material 日期选择器,以便能够选择周.. 因此,当我从一行中选择一个日期时,我希望它输出从一周开始到一周结束的日期范围。 我之前在常规 jquery 日历上这样做过--检查照
在 SwiftUI 中使用新的 (iOS 14) DatePicker,它按预期工作并且在模拟器和设备上看起来很好,但是一旦日历弹出,我会在输出窗口中收到几行警告。这有点烦人! 虽然日志贴在下面,但看
我将如何创建 doctrine_orm_datetime_range使用 jQuery UI 日期选择器的 Sonata Admin Bundle 中的过滤器? 我尝试了以下方法,但不起作用: pro
有人知道如何设置 gem bootstrap-datepicker-rails 吗?我按照 http://rubydoc.info/gems/bootstrap-datepicker-rails/0.
在 kartik DatePicker Yii2 中有没有办法 - 我可以禁用大于当前日期的日期? 例如:如果今天是 2016 年 3 月 14 日,则应禁用 2016 年 3 月 15 日的日历日期
在 UIDatePicker 我们可以做这样的事情 datePicker.timeZone = TimeZone(secondsFromGMT: 5*60*60) 为了指定日期选择器的时区。 但是如何
我在 FullCalendar ( http://www.eyecon.ro/datepicker/ ) 页面正下方添加了一个 datePicker ( http://fullcalendar.io
我在一个 Polymer 项目中有两个 Vaadin-datepickers。一个有开始日期,一个有结束日期。我想确保结束日期总是在开始日期之后。我阅读了 API 文档,他们说您可以使用 min ma
我正在Angular 6中搜索Datepicker,它可以显示基于回历日历的阿拉伯日期。 似乎找不到一个。是否有可用的东西,或者我们需要从头开始构建它。 最佳答案 Ng bootstrap或angul
JavaFX8 中是否有一种方法可以从 Java 代码中选择 DatePicker 中的日期(作为文本)?我想以这样一种方式激活带有 DatePicker 的控件,用户可以在不使用鼠标的情况下编辑日期
我在一个 Polymer 项目中有两个 Vaadin-datepickers。一个有开始日期,一个有结束日期。我想确保结束日期总是在开始日期之后。我阅读了 API 文档,他们说您可以使用 min ma
我正在尝试验证datepicker,因为startDate应始终小于EndDate。如果我手动更改日期,则 StartDate 有效,但 EndDate 无效。 我的JavaScript代码: $(d
我是 jquery 和 javascript 的菜鸟。因此,虽然我看过很多解决我的问题的 SO 帖子,但我无法将各种解决方案“组装”成适合我的东西。 我的上下文:查询结果显示在表单中。在每一行中,其中
我正在开发 Windows Phone 8.1 应用程序。我正在尝试使用 DatePickerFlyout 但没有取得适当的成功。我正在选择日期并尝试用选定的日期设置按钮内容,但它没有设置。当我调试以
我是一名优秀的程序员,十分优秀!