นี่คือบางสิ่งจาก John Resig - http://ejohn.org/blog/javascript-pretty-date/
แก้ไข (27/6/2557): ติดตามความคิดเห็นจากSumurai8 - แม้ว่าหน้าที่เชื่อมโยงจะยังใช้งานได้ แต่นี่คือข้อความที่ตัดตอนมาสำหรับpretty.js
ลิงก์จากบทความด้านบน:
pretty.js
function prettyDate(time) {
var date = new Date((time || "").replace(/-/g, "/").replace(/[TZ]/g, " ")),
diff = (((new Date()).getTime() - date.getTime()) / 1000),
day_diff = Math.floor(diff / 86400);
if (isNaN(day_diff) || day_diff < 0 || day_diff >= 31) return;
return day_diff == 0 && (
diff < 60 && "just now" || diff < 120 && "1 minute ago" || diff < 3600 && Math.floor(diff / 60) + " minutes ago" || diff < 7200 && "1 hour ago" || diff < 86400 && Math.floor(diff / 3600) + " hours ago") || day_diff == 1 && "Yesterday" || day_diff < 7 && day_diff + " days ago" || day_diff < 31 && Math.ceil(day_diff / 7) + " weeks ago";
}
if (typeof jQuery != "undefined") jQuery.fn.prettyDate = function() {
return this.each(function() {
var date = prettyDate(this.title);
if (date) jQuery(this).text(date);
});
};
การใช้งาน:
prettyDate("2008-01-28T20:24:17Z")
prettyDate("2008-01-27T22:24:17Z")
prettyDate("2008-01-26T22:24:17Z")
prettyDate("2008-01-14T22:24:17Z")
prettyDate("2007-12-15T22:24:17Z")
ตัดตอนมาจากบทความเกี่ยวกับการใช้งาน:
ตัวอย่างการใช้งาน
ในตัวอย่างต่อไปนี้ฉันสร้างจุดยึดทั้งหมดบนไซต์ซึ่งมีชื่อเรื่องพร้อมวันที่อยู่ในนั้นมีวันที่ที่สวยงามเป็นข้อความด้านใน นอกจากนี้ฉันยังคงอัปเดตลิงก์ทุก ๆ 5 วินาทีหลังจากที่โหลดเพจแล้ว
ด้วย JavaScript:
function prettyLinks(){
var links = document.getElementsByTagName("a");
for ( var i = 0; i < links.length; i++ )
if ( links[i].title ) {
var date = prettyDate(links[i].title);
if ( date )
links[i].innerHTML = date;
}
}
prettyLinks();
setInterval(prettyLinks, 5000);
ด้วย jQuery:
$("a").prettyDate();
setInterval(function(){ $("a").prettyDate(); }, 5000);
Faiz: ทำการเปลี่ยนแปลงโค้ดดั้งเดิมแก้ไขข้อบกพร่องและปรับปรุง
function prettyDate(time) {
var date = new Date((time || "").replace(/-/g, "/").replace(/[TZ]/g, " ")),
diff = (((new Date()).getTime() - date.getTime()) / 1000),
day_diff = Math.floor(diff / 86400);
var year = date.getFullYear(),
month = date.getMonth()+1,
day = date.getDate();
if (isNaN(day_diff) || day_diff < 0 || day_diff >= 31)
return (
year.toString()+'-'
+((month<10) ? '0'+month.toString() : month.toString())+'-'
+((day<10) ? '0'+day.toString() : day.toString())
);
var r =
(
(
day_diff == 0 &&
(
(diff < 60 && "just now")
|| (diff < 120 && "1 minute ago")
|| (diff < 3600 && Math.floor(diff / 60) + " minutes ago")
|| (diff < 7200 && "1 hour ago")
|| (diff < 86400 && Math.floor(diff / 3600) + " hours ago")
)
)
|| (day_diff == 1 && "Yesterday")
|| (day_diff < 7 && day_diff + " days ago")
|| (day_diff < 31 && Math.ceil(day_diff / 7) + " weeks ago")
);
return r;
}