我正在尝试使用以下内容将dd-mm-yyyy格式的字符串转换为JavaScript中的日期对象:
var from = $("#datepicker").val();
var to = $("#datepickertwo").val();
var f = new Date(from);
var t = new Date(to);
("#datepicker").val()
包含dd-mm-yyyy格式的日期。
当我执行以下操作时,我会收到“无效日期”:
alert(f);
这是因为' - '符号吗?我怎么能克服这个?
答案 0 :(得分:275)
拆分“ - ”
将字符串解析为您需要的部分:
var from = $("#datepicker").val().split("-")
var f = new Date(from[2], from[1] - 1, from[0])
使用正则表达式
var date = new Date("15-05-2018".replace( /(\d{2})-(\d{2})-(\d{4})/, "$2/$1/$3"))
为什么不使用正则表达式?
因为你知道你将处理由三个部分组成的字符串,用连字符分隔。
但是,如果你在另一个字符串中寻找相同的字符串,那么正则表达式就是你的选择。
<强>重用强>
因为您在示例代码中以及代码库中的其他位置不止一次地执行此操作,所以将其包装在函数中:
function toDate(dateStr) {
var parts = dateStr.split("-")
return new Date(parts[2], parts[1] - 1, parts[0])
}
使用as:
var from = $("#datepicker").val()
var to = $("#datepickertwo").val()
var f = toDate(from)
var t = toDate(to)
或者如果你不介意你的函数中的jQuery:
function toDate(selector) {
var from = $(selector).val().split("-")
return new Date(from[2], from[1] - 1, from[0])
}
使用as:
var f = toDate("#datepicker")
var t = toDate("#datepickertwo")
现代JavaScript
如果你能够使用更现代的JS,阵列解构也是一个不错的选择:
function toDate(dateStr) {
const [day, month, year] = dateStr.split("-")
return new Date(year, month - 1, day)
}
答案 1 :(得分:131)
正则表达式示例:
new Date( "13-01-2011".replace( /(\d{2})-(\d{2})-(\d{4})/, "$2/$1/$3") );
答案 2 :(得分:14)
另一种可能性:
var from = "10-11-2011";
var numbers = from.match(/\d+/g);
var date = new Date(numbers[2], numbers[0]-1, numbers[1]);
匹配数字并重新排序
答案 3 :(得分:6)
var from = $("#datepicker").val();
var f = $.datepicker.parseDate("d-m-Y", from);
答案 4 :(得分:6)
使用moment.js示例:
var from = '11-04-2017' // OR $("#datepicker").val();
var milliseconds = moment(from, "DD-MM-YYYY").format('x');
var f = new Date(milliseconds)
答案 5 :(得分:4)
使用以下格式:myDate = new Date('2011-01-03'); // Mon Jan 03 2011 00:00:00
答案 6 :(得分:3)
您还可以在Date()
对象的括号内写一个日期,如下所示:
new Date("Month dd, yyyy hh:mm:ss")
new Date("Month dd, yyyy")
new Date(yyyy,mm,dd,hh,mm,ss)
new Date(yyyy,mm,dd)
new Date(milliseconds)
答案 7 :(得分:3)
就我而言
new Date("20151102034013".replace(/(\d{4})(\d{2})(\d{2})(\d{2})(\d{2})(\d{2})/, "$1-$2-$3T$4:$5:$6"))
结果:2015年11月2日星期一04:40:13 GMT + 0100(CET) 然后我使用.getTime()来处理毫秒
答案 8 :(得分:2)
答案 9 :(得分:1)
请查看Datejs所有那些与日期相关的问题。您也可以通过parseDate函数解决这个问题
答案 10 :(得分:1)
您可以:
var f = new Date(from.split('-').reverse().join('/'));
答案 11 :(得分:0)
你可以使用Regexp。
var result = /^(\d{2})-(\d{2})-(\d{4})$/.exec($("#datepicker").val());
if (result) {
from = new Date(
parseInt(result[3], 10),
parseInt(result[2], 10) - 1,
parseInt(result[1], 10)
);
}
答案 12 :(得分:0)
可接受的答案有点错误
var from = $("#datepicker").val().split("-")
var f = new Date(from[2], from[1] - 1, from[0])
请考虑日期选择器是否包含“ 77-78-7980”,这显然不是有效日期。这将导致:
var f = new Date(7980, 77, 77);
=> Date 7986-08-15T22:00:00.000Z
这可能不是期望的结果。
在MDN网站上对此原因进行了解释:
如果将Date用作具有多个参数的构造函数,则如果值大于其逻辑范围(例如,将13作为月份值或70作为分钟值),则会调整相邻的值。例如。
new Date(2013, 13, 1)
等同于new Date(2014, 1, 1)
。
解决问题的更好方法是:
const stringToDate = function(dateString) {
const [dd, mm, yyyy] = dateString.split("-");
return new Date(`${yyyy}-${mm}-${dd}`);
};
console.log(stringToDate('04-04-2019'));
// Date 2019-04-04T00:00:00.000Z
console.log(stringToDate('77-78-7980'));
// Invalid Date
这使您可以处理无效输入。
例如:
const date = stringToDate("77-78-7980");
if (date === "Invalid Date" || isNaN(date)) {
console.log("It's all gone bad");
} else {
// Do something with your valid date here
}
答案 13 :(得分:0)
let dateString = '13-02-2021' //date string in dd-mm-yyyy format
let dateArray = dateString.split("-");
//dateArray[2] equals to 2021
//dateArray[1] equals to 02
//dateArray[0] equals to 13
// using template literals below
let dateObj = new Date(`${dateArray[2]}-${dateArray[1]}-${dateArray[0]}`);
// dateObj equals to Sat Feb 13 2021 05:30:00 GMT+0530 (India Standard Time)
//I'm from India so its showing GMT+0530
答案 14 :(得分:-1)
new Date().toLocaleDateString();
这很简单,只需将你的日期传递给js Date Object