Heim > Artikel > Web-Frontend > Häufig verwendete Kapselungsmethoden für Date-Objekte und Lösungen für aufgetretene Probleme
In diesem Artikel geht es um häufig verwendete Kapselungsmethoden für Datumsobjekte und um Lösungen für aufgetretene Probleme. Ich hoffe, dass er für Sie hilfreich ist.
Ich verwende das Date-Objekt schon seit langem in JS, aber ich habe die häufig verwendeten Kapselungsfunktionen und aufgetretenen Fallstricke noch nie aufgezeichnet. Ich werde sie aufzeichnen, wenn ich heute Zeit habe, damit ich sie direkt verwenden kann Nächstes Mal und erinnern Sie sich an die Fallstricke, auf die Sie gestoßen sind. Wenn etwas nicht stimmt, hoffe ich, dass Sie es darauf hinweisen können. Ich bin Ihnen sehr dankbar.
Beim Konvertieren eines Datums (ohne Stunden, Minuten und Sekunden) in einen Zeitstempel wird das Datum in eine Uhrzeit umgewandelt, wenn es mit „-“ (01.01.2019) und „/“ (01.01.2019) verkettet wird /01) Die Ergebnisse des Stocherns sind unterschiedlich
Um zu verhindern, dass alle zu viele Beispiele sehen und sich langweilen, komme ich zunächst zum Fazit.
Fazit:
1) Wenn die Daten mit „-“ verbunden sind, der Monat und der Tag kleiner als 9 sind und eine 0 vorangestellt ist, wird bei der Konvertierung in einen Zeitstempel die Zeit in konvertiert standardmäßig 8 Uhr morgens des Tages
2) Wenn die Daten mit „-“ verbunden sind, wenn der Monat und der Tag kleiner als 9 sind und eine 0 vor kleiner als 9 steht, dann ist es wird in einen Zeitstempel umgewandelt.
3) Wenn die Daten mit „-“ verbunden sind, wenn der Monat und der Tag beide kleiner als 9 sind und nur einer vorangestellt ist a 0, dann wird es in einen Zeitstempel umgewandelt. Die Zeit wird standardmäßig auf 12 Uhr morgens des Tages umgewandelt, also 00:00
4) Wenn die Daten mit „-“ verbunden sind, Wenn der Monat und der Tag beide größer als 9 sind, werden sie in Zeitstempel umgewandelt. Die Zeit wird standardmäßig in 8 Uhr morgens des Tages umgewandelt
5) Wenn die Daten mit „/“ verbunden sind, dann bei der Umwandlung in Zeitstempel, sie werden nur in 00:00 Uhr des Tages konvertiert
Zusammenfassung: Wenn bei der Konvertierung von Datumsangaben in Zeitstempel die Stunden und Minuten nicht festgelegt sind, verwenden Sie am besten „/“, um eine Verbindung herzustellen, um eine Abweichung zu vermeiden Zeitstempel für dasselbe Datum, wenn sie auf unterschiedliche Weise geschrieben werden
Das Folgende ist ein Beispiel, um die Schlussfolgerung zu beweisen:
" let time1 = new Date('2019-03-03').getTime(); let time2 = new Date('2019/3/3').getTime(); console.log('获取时间') console.log(time1) console.log(time2) console.log( (time1-time2) / 1000 /60 /60 ) // 8 // 根据本地格式,把Date对象的时间转换为字符串 上午12:00:00也就是 00:00:00 console.log(new Date('2019-03-03').toLocaleString()) // 2019/3/3 上午8:00:00 console.log(new Date('2019-03-12').toLocaleString()) // 2019/3/12 上午8:00:00 console.log(new Date('2019-11-03').toLocaleString()) // 2019/11/3 上午8:00:00 console.log(new Date('2019-3-03').toLocaleString()) // 2019/3/3 上午12:00:00 console.log(new Date('2019-03-3').toLocaleString()) // 2019/3/3 上午12:00:00 console.log(new Date('2019-11-13').toLocaleString()) // 2019/11/13 上午8:00:00 console.log(new Date('2019/03/03').toLocaleString()) // 2019/3/3 上午12:00:00 console.log(new Date('2019/3/3').toLocaleString()) // 2019/3/3 上午12:00:00 console.log(new Date('2019/03/3').toLocaleString()) // 2019/3/3 上午12:00:00 console.log(new Date('2019/3/03').toLocaleString()) // 2019/3/3 上午12:00:00 console.log(new Date('2019/03/12').toLocaleString()) // 2019/3/12 上午12:00:00 console.log(new Date('2019/11/03').toLocaleString()) // 2019/11/3 上午12:00:00 "
1. 将日期格式转换为时间戳的三种方法 "javascript let dateStr = new Date('2019-3-20 18:59:39:123'); let timestamp1 = dateStr.getTime(); // 1553079579123 let timestamp2 = dateStr.valueOf(); // 1553079579123 let timestamp3 = Date.parse(dateStr); // 1553079579000 " date.getTime()、date.valueOf()会精确到毫秒,而Date.parse(date)只能精确到秒,毫秒用000替代 2. 将时间戳转换为日期格式 "javascript function dateFormat(timestamp) { timestamp = (timestamp + '' ).length > 10 ? timestamp : timestamp * 1000; //判断时间戳为几位,10位时加上毫秒,13为的则不管 let date = new Date(timestamp); let year = date.getFullYear(); let month = date.getMonth() + 1 > 9 ? date.getMonth() + 1 : '0' + (date.getMonth() + 1); // 月份从0开始,0~11, 所以显示时要 +1 let day = date.getDate() > 9 ? date.getDate() : '0' + date.getDate() ; let hour = date.getHours() > 9 ? date.getHours() : '0' + date.getHours() ; let minutes = date.getMinutes() > 9 ? date.getMinutes() : '0' + date.getMinutes(); let seconds = date.getSeconds() > 9 ? date.getSeconds() : '0' + date.getSeconds(); return year + '-' + month + '-' + day + ' ' + hour + ':' + minutes + ':' + seconds; } "
/** * @method 计算两个日期之间有几天,包括第一天 * @param beginTime 开始时间的日期 '2019-3-19' || '2019/3/19' * @param endTime 结束时间的日期 '2019-3-20' || '2019/3/19' */ getIntervalDay('2019-03-03', '2019-03-8'); // 若是没有用 正则将格式转换的话得到的结果是5天,转换后是6天 function getIntervalDay(beginTime, endTime) { // 先利用将其转换为统一的格式,因为 '-' 格式下的时间戳转换的结果不一致,原因在本文的开头 beginTime = beginTime.replace(/\-/g, '/'); endTime = endTime.replace(/\-/g, '/'); let time1 = new Date(beginTime).getTime(); let time2 = new Date(endTime).getTime(); // console.log(beginTime) // console.log(endTime) let second = time2 - time1; let day = parseInt(second / (1000 * 60 * 60 * 24)) + 1; // 当天也算进去 return day; }
// 闰年为366天(2月中多一天),平年为365天。 // 闰年有两种: 1)普通闰年:能被4整除但不能被100整除的年份为普通闰年。 // 2)世纪闰年:能被400整除的为世纪闰年。 function getYearAllDay(year) { return (year % 4 === 0 && year % 100 !== 0) || year % 400 === 0 ? 366 : 365; }
// date格式为 'xxxx-xx-xx' 'xxxx/xx/xx' 'xxxx/xx' 'xxxx-xx' function getMonthAllDay(date) { date = new Date(date); let year = date.getFullYear(); let month = date.getMonth() + 1; // 从 Date 对象返回月份 (0 ~ 11)。 let nextMonth = year + '-' + (month + 1); let newDate = new Date(nextMonth); newDate.setDate(0); // 利用设置日期时从1~31设置,当设置为0时,即上个月的最后一天 return newDate.getDate(); }Dieser Artikel ist beendet Weitere spannende Inhalte finden Sie im JavaScript-Tutorial-Video auf der chinesischen PHP-WebsiteKolumne!
Das obige ist der detaillierte Inhalt vonHäufig verwendete Kapselungsmethoden für Date-Objekte und Lösungen für aufgetretene Probleme. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!