var date1 = new Date();
date1.setFullYear(2011, 6, 1);
// 2011-07-01, ok
console.log(date1);
// set date2 the same date as date1
var date2 = date1;
// ...
// now I'm gonna set a new date for date2
date2.setFullYear(2011, 9, 8);
// 2011-10-08, ok
console.log(date2);
// 2011-10-08, wrong, expecting 2011-07-01
// I didn't assign a new date to date1
// WHY is date1 changed?
console.log(date1);
Назначение переменной даты Javascript
Ответ 1
Дата - это объект, поэтому он присваивается как ссылка - простой подход
date2 = new Date( date1 );
Ответ 2
Обе переменные даты - это просто ссылки на один и тот же объект даты в памяти. Поэтому вам нужно date2
быть клоном date1
. Изменение:
var date2 = date1;
:
var date2 = new Date(date1.getTime());
Ответ 3
JavaScript использует pass by reference для Dates * (а также все не примитивы - var o = {}; var j = o; j.foo = 1; console.log(o.foo); //1
. С другой стороны, для Numbers, Strings и Booleans var o = 0; var j = o; j++; console.log(j); // 0
), так что это ожидаемое поведение.
Если вам нужно скопировать дату, вы всегда можете
var date2 = new Date( date1.getTime() );
* Пожалуйста, просмотрите комментарии, чтобы понять, почему это не совсем правильно.
Ответ 4
date2
Это ссылка на date1
.
Чтобы достичь ожидаемых результатов, сделайте следующее:
var date1 = new Date();
date1.setFullYear(2011, 6, 1);
var date2 = new Date();
date2.setTime(date1.valueOf());
Ответ 5
Вам нужно создать копию date1
, в настоящее время date1
и date2
ссылаться на один и тот же объект даты.
var date2 = new Date(date1.valueOf());
Ответ 6
Изменение ответа @SergeS, но Date() объектов в js coerce на число, поэтому вам не требуется getTime():
// general case
var dateValueCopy = new Date(date1);
И пересчитывается с именами переменных OP:
var date2 = new Date(date1);
Ответ 7
<html lang="en">
<head>
<script>
function getDateDiff(time1, time2) {
var str1= time1.split('/');
var str2= time2.split('/');
var t1 = new Date(str1[2], str1[0]-1, str1[1]);
var t2 = new Date(str2[2], str2[0]-1, str2[1]);
var diffMS = t1 - t2;
console.log(diffMS + ' ms');
var diffS = diffMS / 1000;
console.log(diffS + ' ');
var diffM = diffS / 60;
console.log(diffM + ' minutes');
var diffH = diffM / 60;
console.log(diffH + ' hours');
var diffD = diffH / 24;
console.log(diffD + ' days');
alert(diffD);
}
//alert(getDateDiff('10/18/2013','10/14/2013'));
</script>
</head>
<body>
<input type="button" onclick="getDateDiff('10/18/2013','10/14/2013')" value="clickHere()" />
</body>
</html>