คำนวณวันที่เมื่อวานใน JavaScript


คำตอบ:


458
var date = new Date();

date ; //# => Fri Apr 01 2011 11:14:50 GMT+0200 (CEST)

date.setDate(date.getDate() - 1);

date ; //# => Thu Mar 31 2011 11:14:50 GMT+0200 (CEST)

12
ดี เมื่อมองดูครั้งแรกอาจดูเหมือนว่าสิ่งนี้จะล้มเหลวเมื่อgetDateส่งคืนวันของเดือน (เช่น: 1 - 31) แต่จริง ๆ แล้วsetDate(0)กำหนดวันที่เป็นวันสุดท้ายของเดือนก่อนหน้า ใช้ได้กับทุกเบราว์เซอร์หรือไม่
Drew Noakes

1
ไม่สามารถตรวจสอบเบราว์เซอร์ "ทั้งหมด" แต่ทำงานในทุกอย่างที่ฉันทดสอบcamo.githubusercontent.com/ ...
James Kyburz

1
@ Zargold ไม่เข้าใจสิ่งที่คุณหมายถึง โหนด - รุ่น v9.4.0 โหนดวันที่ const = ใหม่วันที่ () ไม่ได้กำหนด> date.toISOString () '2018-02-10T16: 26: 30.821Z'> date.setDate (date.getDate () - 1) 1518193590821> วันที่ .toISOString () '2018-02-09T16: 26: 30.821Z'
James Kyburz

อืมใช่เพิ่งทดสอบมันโดยตรงและคุณพูดถูกไม่แน่ใจว่ากรณีการใช้งานของฉันแตกต่างกันอย่างไร ดังนั้นฉันจะไม่เห็น
Zargold

91

ไม่มีประสิทธิภาพมาก แต่เป็น oneliner:

var yesterday = new Date(new Date().setDate(new Date().getDate()-1));

ด้านบนสร้างDateวัตถุสามอย่างที่สิ้นเปลืองโดยไม่จำเป็น สิ่งนี้สามารถลดลงเป็น instantiation เดียวด้วย:

var yesterday = (function(){this.setDate(this.getDate()-1); return this})
                  .call(new Date)

หรือถ้าคุณต้องการ:

var yesterday = (function(d){ d.setDate(d.getDate()-1); return d})(new Date)

หรือถ้าคุณชอบ ES6 ที่มีฟังก์ชั่นลูกศร:

let yesterday = ( d => new Date(d.setDate(d.getDate()-1)) )(new Date);

6
ฉันต้องการหลีกเลี่ยงการยุ่งกับขอบเขต:var yesterday = (function(d){ d.setDate(d.getDate()-1); return d})(new Date)
Roy Tinker

4
หากคุณต้องการซับแบบหนึ่งให้ใช้งานเช่น Date ใหม่ (Date.now () - 24 * 60 * 60 * 1000) สิ่งนี้มีประโยชน์ในการสร้างวัตถุ Date เพียงหนึ่งรายการเท่านั้น แต่อย่างสุจริตใครก็ตามที่ยังคงรักษารหัสนี้จะเป็นมากมีความสุขมากที่จะเห็นชัดเจนรุ่น 2 บรรทัดกว่าพวกเขาจะมีอะไรบางอย่างฟังก์ชั่นการขว้างปารอบ (หรือมิลลิวินาทีสำหรับเรื่องที่)
Rob Whelan


60

น่าแปลกที่ไม่มีคำตอบสำหรับโซลูชันเบราว์เซอร์ข้ามที่ง่ายที่สุด

หากต้องการค้นหาอย่างแน่นอนเมื่อวานนี้:

var yesterday = new Date(Date.now() - 86400000); // that is: 24 * 60 * 60 * 1000

นั่นคือถ้าคุณต้องการพึ่งพาฟรีมิฉะนั้นฉันขอแนะนำให้ใช้http://momentjs.com


7
สิ่งนี้ทำงานอย่างไรเมื่อการเปลี่ยนแปลงในเวลาออมแสง จะไม่ชนมันข้างหน้า / หลังชั่วโมงหรือไม่
Adam Tegen

19

ในการพูดคุยคำถามทั่วไปและใช้การคำนวณแบบต่าง ๆ ให้ทำดังนี้

var yesterday = new Date((new Date()).valueOf() - 1000*60*60*24);

สิ่งนี้จะสร้างอ็อบเจกต์วันที่ใหม่โดยยึดตามค่าของ "ตอนนี้" เป็นจำนวนเต็มซึ่งแสดงถึงยูนิกซ์ยุคในหน่วยมิลลิวินาทีลบออกหนึ่งวัน

สองวันที่ผ่านมา:

var twoDaysAgo = new Date((new Date()).valueOf() - 1000*60*60*24*2);

ชั่วโมงที่ผ่านมา:

var oneHourAgo = new Date((new Date()).valueOf() - 1000*60*60);

นี่น่าจะเป็นวิธีที่ปลอดภัยที่สุดในขณะที่เราดำเนินการกับ unix epoch ที่แสดงในรูปของมิลลิวินาที ดังนั้นเลขคณิตจึงปลอดภัยกว่าการทำบางอย่างเช่น getDate () - 1 ฉันยังไม่ได้ลอง getDate () - 1 แต่อ้างอิงจากเอกสารของ getDate () มันจะคืนค่า 1 หากวันที่วันนี้เป็นวันที่ 1 ของเดือนใด ๆ และ 1-1 = 0 ไม่ใช่วันที่ที่ถูกต้อง ไม่แน่ใจว่า setDate (0) จะทำงานอย่างไร
Kapil Pendse

1
นี่เป็นวิธีการของฉันแม้ว่าคุณจะสามารถทำให้มันง่ายขึ้นเช่นกันลองทำอะไรใหม่ ๆ เช่น Date (Date.now () - 24 * 60 * 60 * 1000)
Rob Whelan

setDate (0), btw จะดี - มันจะพลิกเป็นวันสุดท้ายของเดือนก่อนหน้า แต่ดูเหมือนว่าเป็นระเบียบเรียบร้อย (และใช้งานง่ายกว่า) ที่จะลดลงแทนมิลลิวินาทีที่นี่สำหรับฉัน - ข้อเสียอย่างเดียวคือ "จำนวนมิลลิวินาทีในหนึ่งวัน" ไม่ชัดเจนดังนั้นจึงเป็นการง่ายที่จะพิมพ์การคำนวณนั้นผิด
Rob Whelan

การทำงานกับเวลา unix ดูเหมือนว่าตัวเลือกที่น่าเชื่อถือมากขึ้น ควรได้คะแนนสูงกว่านี้
Paul

ใช่ฉันชอบวิธีนี้ดีที่สุด มีความกำกวมน้อยกว่า new Date(Date.parse(new Date()) - 86400000)ฉันสิ้นสุดขึ้นไปด้วย แม้ว่าฉันจะชอบ Date.now () ดังนั้นฉันอาจลองแทน มันจะบันทึกวันพิเศษ
coblr

9

ฉันใช้ไลบรารี่ช่วงเวลามันยืดหยุ่นและใช้งานง่ายมาก

ในกรณีของคุณ:

let yesterday = moment().subtract(1, 'day').toDate();

2
คุณควรใช้subtractแทนadd
โทมัส Ayoub

ใช้งานได้ดีเช่นกัน! เป็นงานที่ดีสำหรับ FullCalendar และ ValidRange ของเขา
XenoX

8
new Date(new Date().setDate(new Date().getDate()-1))

3
คุณอาจเพิ่มคำอธิบายหน่อยได้ไหม? การบล็อกรหัสธรรมดาเพียงอย่างเดียวนั้นไม่ใช่สิ่งที่มีประโยชน์เลย
CertainPerformance

ทำงานได้ดี! ขอบคุณ
XenoX


6

var today = new Date();
var yesterday1 = new Date(new Date().setDate(new Date().getDate() - 1));
var yesterday2 = new Date(Date.now() - 86400000);
var yesterday3 = new Date(Date.now() - 1000*60*60*24);
var yesterday4 = new Date((new Date()).valueOf() - 1000*60*60*24);
console.log("Today: "+today);
console.log("Yesterday: "+yesterday1);
console.log("Yesterday: "+yesterday2);
console.log("Yesterday: "+yesterday3);
console.log("Yesterday: "+yesterday4);


5

สิ่งนี้จะสร้างเมื่อวานนี้เวลา 00:00 ด้วยความแม่นยำนาที

var d = new Date();
d.setDate(d.getDate() - 1);
d.setTime(d.getTime()-d.getHours()*3600*1000-d.getMinutes()*60*1000);

2
d.setHours(0,0,0,0);

จะทำเคล็ดลับ


1
มันจะ? ฉันคิดว่านี่เพียงกำหนดชั่วโมงนาทีและวินาทีเป็น 0 แต่ไม่เปลี่ยนวันจริงหรือ
Jesper Bylund

ฉันต้องใช้ตัวเลขติดลบเพื่อไปที่เมื่อวาน: d.setHours(-1,0,0,0). สิ่งนี้จะส่งคืนวันที่ของเมื่อวาน แต่อาจไม่ใช่เวลาที่คุณต้องการ (23:00:00)
cs_pupil

1

ลองสิ่งนี้ใช้ได้กับฉัน:

var today = new Date();
var yesterday = new Date(today.setDate(today.getDate() - 1)); `

สิ่งนี้ทำให้ฉันมีวันที่กลับมาเมื่อวาน


1
เนื่องจากคุณใช้วันนี้ชุดวันที่วันนี้จะเปลี่ยนเป็นเมื่อวานเช่นกัน จะดีกว่าถ้าสร้างตัวแปรเมื่อวานแล้วตั้งค่า var yesterday = new Date(); yesterday.setDate(today.GetDate() - 1)เพื่อให้คุณสามารถใช้ทั้งวันนี้และเมื่อวาน
PersyJack

1

นี่คือหนึ่งซับที่ใช้เพื่อรับวันที่วันวานในรูปแบบ YYYY-MM-DD ในข้อความและจัดการกับเขตเวลาชดเชย

new Date(Date.now() - 1 * 86400000 - new Date().getTimezoneOffset() * 60000).toISOString().split('T')[0]

มันสามารถเปลี่ยนเป็นวันที่กลับอย่างรวดเร็ว x ย้อนกลับไปในเวลา รวมเวลา ฯลฯ

console.log(Date())
console.log(new Date(Date.now() - 1 * 86400000 - new Date().getTimezoneOffset() * 60000).toISOString().split('T')[0]); // "2019-11-11"
console.log(new Date(Date.now() - 1 * 86400000 - new Date().getTimezoneOffset() * 60000).toISOString().split('.')[0].replace('T',' ')); // "2019-11-11 11:11:11"

// that is: [dates] * 24 * 60 * 60 * 1000 - offsetinmin * 60 * 1000    // this is: [dates] * 24 * 60 * 60 * 1000 - offsetinmin * 60 * 1000


0

หากคุณต้องการได้รับวันที่เมื่อวานและจัดรูปแบบวันที่ในรูปแบบที่มนุษย์สามารถอ่านได้ให้พิจารณาสร้างDateHelperวัตถุแบบกำหนดเองที่มีลักษณะดังนี้:

var DateHelper = {
    addDays : function(aDate, numberOfDays) {
        aDate.setDate(aDate.getDate() + numberOfDays); // Add numberOfDays
        return aDate;                                  // Return the date
    },
    format : function format(date) {
        return [
           ("0" + date.getDate()).slice(-2),           // Get day and pad it with zeroes
           ("0" + (date.getMonth()+1)).slice(-2),      // Get month and pad it with zeroes
           date.getFullYear()                          // Get full year
        ].join('/');                                   // Glue the pieces together
    }
}

// With this helper, you can now just use one line of readable code to :
// ---------------------------------------------------------------------
// 1. Get the current date
// 2. Subtract 1 day
// 3. Format it
// 4. Output it
// ---------------------------------------------------------------------
document.body.innerHTML = DateHelper.format(DateHelper.addDays(new Date(), -1));

(ดูซอนี้ )


0

คุณสามารถใช้ momentjs มันมีประโยชน์มากที่คุณสามารถทำสิ่งต่างๆมากมายด้วยห้องสมุดนี้

รับวันที่เมื่อวานกับเวลาปัจจุบัน moment().subtract(1, 'days').toString()

รับวันที่เมื่อวานโดยเริ่มวันที่ moment().subtract(1, 'days').startOf('day').toString()


0

แก้ปัญหาขอบเขตวันที่ (2020, 01, 01) -> 2019, 12, 31

var now = new Date();
return new Date(now.getMonth() - 1 === 0 ? now.getFullYear() - 1 : now.getFullYear(),
                now.getDate() - 1 === 0 ? now.getMonth() - 1: now.getMonth(),
                now.getDate() - 1);

-1

"Date.now () - 86400000" จะไม่ทำงานในวันสิ้นสุดการเลื่อนเวลาตามฤดูกาล (ซึ่งมี 25 ชั่วโมงในวันนั้น)

ตัวเลือกอื่นคือใช้การปิด:

var d = new goog.date.Date();
d.add(new goog.date.Interval(0, 0, -1));
โดยการใช้ไซต์ของเรา หมายความว่าคุณได้อ่านและทำความเข้าใจนโยบายคุกกี้และนโยบายความเป็นส่วนตัวของเราแล้ว
Licensed under cc by-sa 3.0 with attribution required.