MySQL 데이터베이스에 시간을 유닉스 타임스탬프로 저장하고 있는데 이 시간이 일부 JavaScript 코드로 전송됩니다. 이 데이터베이스에서 시간만 추출하려면 어떻게 해야 하나요?
예를 들어, HH/MM/SS 형식입니다.
// 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);
Date 객체에 대한 자세한 내용은 MDN 또는 ECMAScript 5 사양을 참조하세요.
<! - begin 스니핏: js 숨기십시오: 거짓값 콘솔: 진정한 바벨. > 거짓값 -;
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));
끝 - < 스니핏 >;!
다음은 가장 짧은 한 줄 광고문 솔루션이므로 포맷하십시오 초 만에 '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"
>. '다테.프로토티페스투아오스트링 ()' 에서 시간을 되돌려줍니다 방법 >. 단순화됨 확장됨 ISO 8601 24 개, 이는 항상 형식 (즉, '또는' YYYY-MM-DDTHH:mm:ss.sssZ 자입니다. >. & # 177 YYYYYY-MM-DDTHH:mm:ss.sssZ ',' 이다. 항상 이 시간대 >. 제로 UTC 오프셋입니다.
사용:
var s = new Date(1504095567183).toLocaleDateString("en-US")
// expected output "8/30/2017"
및 시간:
var s = new Date(1504095567183).toLocaleTimeString("en-US")
// expected output "3:19:27 PM"`
유닉스 기반으로 시간스탬프와:
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") );
UNIX 타임스탬프는 1970년 1월 1일 00:00:00 UTC(위키백과에 따름) 이후 초의 시간입니다.
자바스크립트에서 Date 객체의 인수는 1970년 1월 1일 UTC 00:00:00 이후 밀리초 수입니다(W3Schools 자바스크립트 문서에 따름).
예를 들어 아래 코드를 참조하세요:
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)
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;
}
린트레비다테타임포르마 은 한때 비 문화 포맷하십시오 운행에서어떠한 날짜 / 시간.
// 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());
지켜보리니 날짜 / Epoch 변환기 .
그렇지 않으면 ',' t work: # 39 wouldn& 페르세인트 합니다.
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;