Подтвердить что ты не робот

Назначение переменной даты Javascript

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);
4b9b3361

Ответ 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>