ฉันกำลังจัดเก็บเวลาในฐานข้อมูล MySQL เป็นเวลา Unix และที่ถูกส่งไปยังโค้ด JavaScript บางตัว ฉันจะใช้เวลาให้มันได้อย่างไร
ตัวอย่างเช่นในรูปแบบ HH / MM / SS
ฉันกำลังจัดเก็บเวลาในฐานข้อมูล MySQL เป็นเวลา Unix และที่ถูกส่งไปยังโค้ด JavaScript บางตัว ฉันจะใช้เวลาให้มันได้อย่างไร
ตัวอย่างเช่นในรูปแบบ HH / MM / SS
คำตอบ:
let unix_timestamp = 1549312452
// Create a new JavaScript Date object based on the timestamp
// multiplied by 1000 so that the argument is in milliseconds, not seconds.
var date = new Date(unix_timestamp * 1000);
// Hours part from the timestamp
var hours = date.getHours();
// Minutes part from the timestamp
var minutes = "0" + date.getMinutes();
// Seconds part from the timestamp
var seconds = "0" + date.getSeconds();
// Will display time in 10:30:23 format
var formattedTime = hours + ':' + minutes.substr(-2) + ':' + seconds.substr(-2);
console.log(formattedTime);
สำหรับข้อมูลเพิ่มเติมเกี่ยวกับวัตถุวันโปรดดูที่MDNหรือECMAScript 5 สเปค
function timeConverter(UNIX_timestamp){
var a = new Date(UNIX_timestamp * 1000);
var months = ['Jan','Feb','Mar','Apr','May','Jun','Jul','Aug','Sep','Oct','Nov','Dec'];
var year = a.getFullYear();
var month = months[a.getMonth()];
var date = a.getDate();
var hour = a.getHours();
var min = a.getMinutes();
var sec = a.getSeconds();
var time = date + ' ' + month + ' ' + year + ' ' + hour + ':' + min + ':' + sec ;
return time;
}
console.log(timeConverter(0));
var min = a.getMinutes() < 10 ? '0' + a.getMinutes() : a.getMinutes(); var sec = a.getSeconds() < 10 ? '0' + a.getSeconds() : a.getSeconds();
getMonth()
ส่งกลับหมายเลขเดือนระหว่าง 0 ถึง 11 ดังนั้นจึงa.getMonth() - 1
ผิด
JavaScript ใช้งานได้ในมิลลิวินาทีดังนั้นคุณจะต้องแปลงเวลาของ UNIX จากวินาทีเป็นมิลลิวินาที
var date = new Date(UNIX_Timestamp * 1000);
// Manipulate JavaScript Date object here...
ฉันเป็นส่วนหนึ่งของDate.format()
ห้องสมุดJacob Wright ซึ่งใช้รูปแบบวันที่ของ JavaScript ในรูปแบบการdate()
ทำงานของ PHP
new Date(unix_timestamp * 1000).format('h:i:s')
format is not a function
js แต่วิธีนี้ใช้งานได้ดี: stackoverflow.com/a/34015511/7550772
ใช้:
var s = new Date(1504095567183).toLocaleDateString("en-US")
console.log(s)
// expected output "8/30/2017"
และสำหรับเวลา:
var s = new Date(1504095567183).toLocaleTimeString("en-US")
console.log(s)
// expected output "3:19:27 PM"
toLocaleString
รวมถึงวันที่และเวลา
นี่คือวิธีแก้ปัญหาหนึ่งซับที่สั้นที่สุดเพื่อจัดรูปแบบวินาทีเป็นhh:mm:ss
:
/**
* Convert seconds to time string (hh:mm:ss).
*
* @param Number s
*
* @return String
*/
function time(s) {
return new Date(s * 1e3).toISOString().slice(-13, -5);
}
console.log( time(12345) ); // "03:25:45"
วิธีการ
Date.prototype.toISOString()
ส่งกลับในเวลาง่ายขยายISO 8601รูปแบบซึ่งเป็นเสมอ 24 หรือ 27 ตัวอักษร (เช่นYYYY-MM-DDTHH:mm:ss.sssZ
หรือ±YYYYYY-MM-DDTHH:mm:ss.sssZ
ตามลำดับ) เขตเวลาเป็นออฟเซ็ต UTC ศูนย์เสมอ
หมายเหตุ: การแก้ปัญหานี้ไม่จำเป็นต้องมีห้องสมุดบุคคลที่สามและได้รับการสนับสนุนในเบราว์เซอร์ที่ทันสมัยและเครื่องมือ JavaScript
toTimeString
ถูกไม่ทำงานกับเขตเวลาได้ดี น่าเสียดายที่การแก้ไขของคุณถูกปฏิเสธก่อนที่ฉันจะเห็นมัน อย่างไรก็ตามฉันขอแนะนำให้ใช้toISOString
แทนเนื่องจากtoGMTString
เลิกใช้แล้วและอาจส่งคืนผลลัพธ์ที่แตกต่างกันในแพลตฟอร์มที่แตกต่างกัน
ฉันคิดถึงการใช้ห้องสมุดเช่นmomentjs.comซึ่งทำให้สิ่งนี้ง่ายมาก:
ขึ้นอยู่กับการประทับเวลา Unix:
var timestamp = moment.unix(1293683278);
console.log( timestamp.format("HH/mm/ss") );
ขึ้นอยู่กับสตริงวันที่ MySQL:
var now = moment("2010-10-10 12:03:15");
console.log( now.format("HH/mm/ss") );
console.log
ตัวอย่างของคุณฉันสับสนเกี่ยวกับรูปแบบเนื่องจากการ/
แต่มันช่วยฉันได้มาก
UNIX Timestamp คือจำนวนวินาทีตั้งแต่ 00:00:00 UTC วันที่ 1 มกราคม 1970 (อ้างอิงจากWikipedia )
อาร์กิวเมนต์ของวันที่วัตถุใน Javascript คือจำนวนของmilisecondsตั้งแต่ 00:00:00 UTC วันที่ 1 มกราคม 1970 (ตามเอกสาร W3Schools Javascript )
ดูรหัสด้านล่างตัวอย่างเช่น:
function tm(unix_tm) {
var dt = new Date(unix_tm*1000);
document.writeln(dt.getHours() + '/' + dt.getMinutes() + '/' + dt.getSeconds() + ' -- ' + dt + '<br>');
}
tm(60);
tm(86400);
ให้:
1/1/0 -- Thu Jan 01 1970 01:01:00 GMT+0100 (Central European Standard Time)
1/0/0 -- Fri Jan 02 1970 01:00:00 GMT+0100 (Central European Standard Time)
วิธีแก้ปัญหาหนึ่งซับที่สั้นที่สุดเพื่อจัดรูปแบบวินาทีเป็น hh: mm: ss: Variant:
console.log(new Date(1549312452 * 1000).toISOString().slice(0, 19).replace('T', ' '));
// "2019-02-04 20:34:12"
ใช้Moment.jsคุณจะได้รับเวลาและวันที่เช่นนี้:
var dateTimeString = moment(1439198499).format("DD-MM-YYYY HH:mm:ss");
และคุณสามารถใช้เวลานี้ในการ:
var timeString = moment(1439198499).format("HH:mm:ss");
ปัญหาของการแก้ปัญหาดังกล่าวคือถ้าชั่วโมงนาทีหรือวินาทีมีเพียงหนึ่งหลัก (เช่น 0-9) เวลาจะผิดเช่นมันอาจเป็น 2: 3: 9 แต่ควรเป็น 02: 03:09
ตามหน้านี้ดูเหมือนว่าจะเป็นวิธีที่ดีกว่าในการใช้วิธี "toLocaleTimeString" ของ Date
date.toLocaleTimeString()
อีกวิธีหนึ่ง - นับจากวันที่ISO 8601
var timestamp = 1293683278;
var date = new Date(timestamp * 1000);
var iso = date.toISOString().match(/(\d{2}:\d{2}:\d{2})/)
alert(iso[1]);
ในเวลาที่คุณต้องใช้การประทับเวลา unix:
var dateTimeString = moment.unix(1466760005).format("DD-MM-YYYY HH:mm:ss");
ตามคำตอบของ @ shomrat นี่คือตัวอย่างข้อมูลที่เขียน datetime โดยอัตโนมัติเช่นนี้ (คล้ายกับวันที่ของ StackOverflow สำหรับคำตอบ:) answered Nov 6 '16 at 11:51
:
today, 11:23
หรือ
yersterday, 11:23
หรือ (ถ้าต่างกัน แต่ปีเดียวกันมากกว่าวันนี้)
6 Nov, 11:23
หรือ (ถ้าอีกปีกว่าวันนี้)
6 Nov 2016, 11:23
function timeConverter(t) {
var a = new Date(t * 1000);
var today = new Date();
var yesterday = new Date(Date.now() - 86400000);
var months = ['Jan', 'Feb', 'Mar', 'Apr', 'May', 'Jun', 'Jul', 'Aug', 'Sep', 'Oct', 'Nov', 'Dec'];
var year = a.getFullYear();
var month = months[a.getMonth()];
var date = a.getDate();
var hour = a.getHours();
var min = a.getMinutes();
if (a.setHours(0,0,0,0) == today.setHours(0,0,0,0))
return 'today, ' + hour + ':' + min;
else if (a.setHours(0,0,0,0) == yesterday.setHours(0,0,0,0))
return 'yesterday, ' + hour + ':' + min;
else if (year == today.getFullYear())
return date + ' ' + month + ', ' + hour + ':' + min;
else
return date + ' ' + month + ' ' + year + ', ' + hour + ':' + min;
}
โซลูชันที่ทันสมัยที่ไม่ต้องการไลบรารี 40 KB:
Intl.DateTimeFormatเป็นวิธีจักรวรรดินิยมที่ไม่ใช่วัฒนธรรมในการจัดรูปแบบวันที่ / เวลา
// Setup once
var options = {
//weekday: 'long',
//month: 'short',
//year: 'numeric',
//day: 'numeric',
hour: 'numeric',
minute: 'numeric',
second: 'numeric'
},
intlDate = new Intl.DateTimeFormat( undefined, options );
// Reusable formatter
var timeStamp = 1412743273;
console.log( intlDate.format( new Date( 1000 * timeStamp ) ) );
การประทับเวลาของฉันถูกดึงมาจากแบ็กเอนด์ PHP ฉันลองใช้วิธีการทั้งหมดข้างต้นแล้ว แต่ก็ไม่ได้ผล จากนั้นฉันได้พบกับบทช่วยสอนที่ใช้งานได้:
var d =val.timestamp;
var date=new Date(+d); //NB: use + before variable name
console.log(d);
console.log(date.toDateString());
console.log(date.getFullYear());
console.log(date.getMinutes());
console.log(date.getSeconds());
console.log(date.getHours());
console.log(date.toLocaleTimeString());
วิธีการข้างต้นจะสร้างผลลัพธ์นี้
1541415288860
Mon Nov 05 2018
2018
54
48
13
1:54:48 PM
มีวิธีการมากมายที่ใช้งานได้ดีกับการประทับเวลา ลาดเทรายการพวกเขาทั้งหมด
function getTIMESTAMP() {
var date = new Date();
var year = date.getFullYear();
var month = ("0" + (date.getMonth() + 1)).substr(-2);
var day = ("0" + date.getDate()).substr(-2);
var hour = ("0" + date.getHours()).substr(-2);
var minutes = ("0" + date.getMinutes()).substr(-2);
var seconds = ("0" + date.getSeconds()).substr(-2);
return year + "-" + month + "-" + day + " " + hour + ":" + minutes + ":" + seconds;
}
//2016-01-14 02:40:01
เอาใจใส่กับปัญหาศูนย์กับคำตอบบางอย่าง ตัวอย่างเช่นการประทับเวลา1439329773
จะถูกแปลงโดยไม่ตั้งใจไป12/08/2015 0:49
จะถูกแปลงหลงผิด
ฉันขอแนะนำให้ใช้สิ่งต่อไปนี้เพื่อแก้ไขปัญหานี้:
var timestamp = 1439329773; // replace your timestamp
var date = new Date(timestamp * 1000);
var formattedDate = ('0' + date.getDate()).slice(-2) + '/' + ('0' + (date.getMonth() + 1)).slice(-2) + '/' + date.getFullYear() + ' ' + ('0' + date.getHours()).slice(-2) + ':' + ('0' + date.getMinutes()).slice(-2);
console.log(formattedDate);
ตอนนี้ผลลัพธ์ใน:
12/08/2015 00:49
// Format value as two digits 0 => 00, 1 => 01
function twoDigits(value) {
if(value < 10) {
return '0' + value;
}
return value;
}
var date = new Date(unix_timestamp*1000);
// display in format HH:MM:SS
var formattedTime = twoDigits(date.getHours())
+ ':' + twoDigits(date.getMinutes())
+ ':' + twoDigits(date.getSeconds());
function timeConverter(UNIX_timestamp){
var a = new Date(UNIX_timestamp*1000);
var hour = a.getUTCHours();
var min = a.getUTCMinutes();
var sec = a.getUTCSeconds();
var time = hour+':'+min+':'+sec ;
return time;
}
ดูวันที่ / Epoch แปลง
คุณต้องการParseInt
มิฉะนั้นมันจะไม่ทำงาน:
if (!window.a)
window.a = new Date();
var mEpoch = parseInt(UNIX_timestamp);
if (mEpoch < 10000000000)
mEpoch *= 1000;
------
a.setTime(mEpoch);
var year = a.getFullYear();
...
return time;
คุณสามารถใช้ฟังก์ชั่นต่อไปนี้เพื่อแปลงเวลาของคุณเป็นHH:MM:SS
รูปแบบ:
var convertTime = function(timestamp, separator) {
var pad = function(input) {return input < 10 ? "0" + input : input;};
var date = timestamp ? new Date(timestamp * 1000) : new Date();
return [
pad(date.getHours()),
pad(date.getMinutes()),
pad(date.getSeconds())
].join(typeof separator !== 'undefined' ? separator : ':' );
}
โดยไม่ผ่านตัวคั่นจะใช้:
เป็นตัวคั่น (ค่าเริ่มต้น):
time = convertTime(1061351153); // --> OUTPUT = 05:45:53
หากคุณต้องการใช้/
เป็นตัวคั่นเพียงแค่ส่งเป็นพารามิเตอร์ตัวที่สอง:
time = convertTime(920535115, '/'); // --> OUTPUT = 09/11/55
var convertTime = function(timestamp, separator) {
var pad = function(input) {return input < 10 ? "0" + input : input;};
var date = timestamp ? new Date(timestamp * 1000) : new Date();
return [
pad(date.getHours()),
pad(date.getMinutes()),
pad(date.getSeconds())
].join(typeof separator !== 'undefined' ? separator : ':' );
}
document.body.innerHTML = '<pre>' + JSON.stringify({
920535115 : convertTime(920535115, '/'),
1061351153 : convertTime(1061351153, ':'),
1435651350 : convertTime(1435651350, '-'),
1487938926 : convertTime(1487938926),
1555135551 : convertTime(1555135551, '.')
}, null, '\t') + '</pre>';
ดูซอนี้
function getDateTimeFromTimestamp(unixTimeStamp) {
var date = new Date(unixTimeStamp);
return ('0' + date.getDate()).slice(-2) + '/' + ('0' + (date.getMonth() + 1)).slice(-2) + '/' + date.getFullYear() + ' ' + ('0' + date.getHours()).slice(-2) + ':' + ('0' + date.getMinutes()).slice(-2);
}
var myTime = getDateTimeFromTimestamp(1435986900000);
console.log(myTime); // output 01/05/2000 11:00
หากคุณต้องการแปลงระยะเวลา Unix เป็นชั่วโมงนาทีและวินาทีจริงคุณสามารถใช้รหัสต่อไปนี้:
var hours = Math.floor(timestamp / 60 / 60);
var minutes = Math.floor((timestamp - hours * 60 * 60) / 60);
var seconds = Math.floor(timestamp - hours * 60 * 60 - minutes * 60 );
var duration = hours + ':' + minutes + ':' + seconds;
function getDateTime(unixTimeStamp) {
var d = new Date(unixTimeStamp);
var h = (d.getHours().toString().length == 1) ? ('0' + d.getHours()) : d.getHours();
var m = (d.getMinutes().toString().length == 1) ? ('0' + d.getMinutes()) : d.getMinutes();
var s = (d.getSeconds().toString().length == 1) ? ('0' + d.getSeconds()) : d.getSeconds();
var time = h + '/' + m + '/' + s;
return time;
}
var myTime = getDateTime(1435986900000);
console.log(myTime); // output 01/15/00
โค้ดด้านล่างนี้ยังมีมิลลิวินาที 3 หลักเหมาะสำหรับคำนำหน้าบันทึกคอนโซล:
const timeStrGet = date => {
const milliSecsStr = date.getMilliseconds().toString().padStart(3, '0') ;
return `${date.toLocaleTimeString('it-US')}.${milliSecsStr}`;
};
setInterval(() => console.log(timeStrGet(new Date())), 299);
แปลงเวลาประทับเป็นสตริงวันที่ใน js
moment().format('YYYY-MM-DD hh:mm:ss');
// "2020-01-10 11:55:43"
moment(1578478211000).format('YYYY-MM-DD hh:mm:ss');
// "2020-01-08 06:10:11"
day.js
github.com/iamkun/dayjs
คำตอบที่ได้รับจาก @Aron ทำงานได้ แต่มันไม่ได้ผลสำหรับฉันเนื่องจากฉันพยายามแปลงเวลาเริ่มจาก 1980 ดังนั้นฉันจึงทำการเปลี่ยนแปลงเล็กน้อยดังนี้
function ConvertUnixTimeToDateForLeap(UNIX_Timestamp) {
var dateObj = new Date(1980, 0, 1, 0, 0, 0, 0);
dateObj.setSeconds(dateObj.getSeconds() + UNIX_Timestamp);
return dateObj;
}
document.body.innerHTML = 'TimeStamp : ' + ConvertUnixTimeToDateForLeap(1269700200);
ดังนั้นหากคุณมีการประทับเวลาเริ่มต้นจากอีกทศวรรษหรือมากกว่านั้นให้ใช้สิ่งนี้ มันช่วยลดอาการปวดหัวได้มากสำหรับฉัน