Updated
เรามีห้องสมุด UI ภายในที่มีการรับมือกับทั้งไมโครซอฟท์ ASP.NET ในตัวรูปแบบ JSON เช่น/Date(msecs)/
ถามเกี่ยวกับที่นี่ แต่เดิมและรูปแบบวัน JSON รวมทั้ง JSON.NET 2014-06-22T00:00:00.0
ของมากที่สุดเช่น นอกจากนี้เรายังต้องรับมือกับoldIE ที่ไม่สามารถรับมือกับอะไรได้นอกจากทศนิยม 3 ตำแหน่งตำแหน่งทศนิยม
ก่อนอื่นเราตรวจสอบว่าเราใช้วันที่ชนิดใดแยกวิเคราะห์เป็น JavaScript ปกติ Date
วัตถุแล้วจัดรูปแบบที่ออก
1) ตรวจสอบรูปแบบวันที่ของ Microsoft
// Handling of Microsoft AJAX Dates, formatted like '/Date(01238329348239)/'
function looksLikeMSDate(s) {
return /^\/Date\(/.test(s);
}
2) ตรวจสอบรูปแบบวันที่ ISO
var isoDateRegex = /^(\d\d\d\d)-(\d\d)-(\d\d)T(\d\d):(\d\d):(\d\d)(\.\d\d?\d?)?([\+-]\d\d:\d\d|Z)?$/;
function looksLikeIsoDate(s) {
return isoDateRegex.test(s);
}
3) รูปแบบวันที่แยกวิเคราะห์ MS:
function parseMSDate(s) {
// Jump forward past the /Date(, parseInt handles the rest
return new Date(parseInt(s.substr(6)));
}
4) รูปแบบวันที่แยกวิเคราะห์ ISO
อย่างน้อยเรามีวิธีที่จะทำให้แน่ใจว่าเรากำลังจัดการกับวันที่ ISO มาตรฐานหรือวันที่ ISO ที่แก้ไขให้มีสามมิลลิวินาทีเสมอ (ดูด้านบน ) เสมอดังนั้นรหัสจึงแตกต่างกันไปขึ้นอยู่กับสภาพแวดล้อม
4a) รูปแบบวันที่ ISO แบบแยกวิเคราะห์รับมือกับปัญหาของ oldIE:
function parseIsoDate(s) {
var m = isoDateRegex.exec(s);
// Is this UTC, offset, or undefined? Treat undefined as UTC.
if (m.length == 7 || // Just the y-m-dTh:m:s, no ms, no tz offset - assume UTC
(m.length > 7 && (
!m[7] || // Array came back length 9 with undefined for 7 and 8
m[7].charAt(0) != '.' || // ms portion, no tz offset, or no ms portion, Z
!m[8] || // ms portion, no tz offset
m[8] == 'Z'))) { // ms portion and Z
// JavaScript's weirdo date handling expects just the months to be 0-based, as in 0-11, not 1-12 - the rest are as you expect in dates.
var d = new Date(Date.UTC(m[1], m[2]-1, m[3], m[4], m[5], m[6]));
} else {
// local
var d = new Date(m[1], m[2]-1, m[3], m[4], m[5], m[6]);
}
return d;
}
4b) แยกวิเคราะห์รูปแบบ ISO ด้วยทศนิยมสามมิลลิวินาทีคงที่ - ง่ายกว่ามาก:
function parseIsoDate(s) {
return new Date(s);
}
5) จัดรูปแบบ:
function hasTime(d) {
return !!(d.getUTCHours() || d.getUTCMinutes() || d.getUTCSeconds());
}
function zeroFill(n) {
if ((n + '').length == 1)
return '0' + n;
return n;
}
function formatDate(d) {
if (hasTime(d)) {
var s = (d.getMonth() + 1) + '/' + d.getDate() + '/' + d.getFullYear();
s += ' ' + d.getHours() + ':' + zeroFill(d.getMinutes()) + ':' + zeroFill(d.getSeconds());
} else {
var s = (d.getMonth() + 1) + '/' + d.getDate() + '/' + d.getFullYear();
}
return s;
}
6) ผูกมันทั้งหมดเข้าด้วยกัน:
function parseDate(s) {
var d;
if (looksLikeMSDate(s))
d = parseMSDate(s);
else if (looksLikeIsoDate(s))
d = parseIsoDate(s);
else
return null;
return formatDate(d);
}
คำตอบเก่าด้านล่างมีประโยชน์สำหรับการคาดเดาวันที่จัดรูปแบบนี้เป็นการแยกวิเคราะห์ JSON ของ jQuery เพื่อให้คุณได้รับวัตถุวันที่แทนสตริงหรือถ้าคุณยังคงติดอยู่ใน jQuery <1.5 อย่างใด
คำตอบเก่า
หากคุณใช้ฟังก์ชั่น Ajax ของ jQuery 1.4 กับ ASP.NET MVC คุณสามารถเปลี่ยนคุณสมบัติ DateTime ทั้งหมดเป็นวัตถุวันที่ด้วย:
// Once
jQuery.parseJSON = function(d) {return eval('(' + d + ')');};
$.ajax({
...
dataFilter: function(d) {
return d.replace(/"\\\/(Date\(-?\d+\))\\\/"/g, 'new $1');
},
...
});
ใน jQuery 1.5 คุณสามารถหลีกเลี่ยงการแทนที่parseJSON
เมธอดทั่วโลกโดยใช้ตัวเลือกตัวแปลงในการโทร Ajax
http://api.jquery.com/jQuery.ajax/
น่าเสียดายที่คุณต้องเปลี่ยนไปใช้เส้นทาง eval รุ่นเก่าเพื่อให้ Dates แยกวิเคราะห์ทั่วโลกแทน - ไม่เช่นนั้นคุณต้องแปลงเป็นรายกรณีเพิ่มเติม