Предыстория Я уже неделю ломаю голову, пытаясь просто сохранить и возобновить даты планирования в JS. Чтобы сохранить даты между сеансами, мне нужно использовать Stringify для разгрузки одной строки, которая будет сохранена как переменная. Я программирую JS в пользовательском движке (Barco's Medialon), который не допускает включения или стандартного ввода-вывода. Таким образом, все должно работать в этом одном блоке кода с небольшими вещами, которые не являются стандартными или требуют обходных путей.
Проблема Эта команда JSON stringify сохраняет объекты даты в стандартном формате «2019-03-05T09:20:00.000Z». Однако эта конкретная команда JSON parsing//new Date() не может интерпретировать этот строковый формат и создает ошибку « Недействительная дата". Однако другие форматы работают, IE, когда я вызываю новую дату (время эпохи) или новую дату (ГГГГ, ММ, ДД, чч, мм)
Приключение Я пытаюсь изменить разделы stringify/parse, чтобы обойти эту проблему, хотя у меня не получается. Хотя у меня есть небольшой дескриптор бита «JSON.parse» и регулярного выражения, попытка манипулировать обнаружением объекта Date и изменением способа его кодирования до сих пор является бесполезной задачей.
Структура объекта становится строковой
{
"daily": "",
"special": [
{
"startDTG": "2019-03-05T09:20:00.000Z", // <- Without modifying the default stringify it gives this
"endDTG": "2019-03-06T09:20:00.000Z",
"mode": "0"
}
],
"current": {},
"startup": [],
"shutdown": []
}
Я пробовал следующие манипуляции со стригами:
var currentEvents = JSON.stringify(this.Events, function(key,value) {
if (value instanceof Date){
return value.getTime();
}
return value;
});
Однако вышеприведенное не обнаруживает объект Date. Если я использую (typeof value === 'object'), он слишком сильно активируется.
С другой стороны, вот нерабочий для этого движка (но работает везде!) код
eventLoad = JSON.parse(eventSTR, function (key, value) {
var reISO = /^(\d{4})-(\d{2})-(\d{2})T(\d{2}):(\d{2}):(\d{2}(?:\.\d*))(?:Z|(\+|-)([\d|:]*))?$/;
if (typeof value === 'string' && reISO.test(value)){
return new Date(value); //value.slice(0,-5));
}
return value;
});
Цель Мне нужно найти решение для обхода ограничений этого движка, которое позволяет мне обнаруживать и преобразовывать дату в строку во время процесса JSON.stringify в альтернативной форме, которая также позволяет функции JSON.Parse обнаруживать и импортировать ее. назад как объект Date
test не работает? Это new Date неправильно интерпретирует аргумент? Если да, то как? Есть ли исключение?
@trincot Сам сбой возникает, когда ``` new Date("2019-03-06T09:20:00.000Z"); ``` вызывается. Результатом является искаженный объект Date, в котором не работают функции получения. Отладчик, предоставляемый этим движком, не жалуется, кроме сообщения «Неверная дата». и когда я привожу объект Date к строке, я получаю только ту же «Неверную дату» @geoidesic. Я переписал часть цели с более четким вопросом.
Date? Почему он должен обнаруживать (другие) строки?
@trincot Я исправил словосочетание, которое от моего имени было мозговым пердежом, оно не обнаруживало объекты даты.



![Безумие обратных вызовов в javascript [JS]](https://i.imgur.com/WsjO6zJb.png)


Вы пытаетесь сделать все это вручную, но уже есть методы для обработки всех этих преобразований.
Дата ISO: https://www.w3schools.com/jsref/jsref_toisostring.asp
ISO на сегодняшний день: Преобразование даты ISO в формат даты yyyy-mm-dd в javascript
И специально для формата :00.000Z см. этот ответ:
Что означает этот формат T00:00:00.000Z?
Moment.js также отлично экономит время для таких вещей: http://momentjs.com/
В обратном вызове JSON.parse вы можете вызвать Date.UTC с 7 аргументами и передать полученное значение эпохи в конструктор Date, например:
var p = value.match(/\d+/g);
return new Date(Date.UTC(p[0],p[1]-1,p[2],p[3],p[4],p[5],p[6]));
Это предполагает, что строковая дата использует формат UTC с указанием часового пояса "Z". Вот что JSON.stringify выдает для фиников.
Демо:
var event = {
dt: new Date()
};
console.info("input:");
console.info(event);
var eventSTR = JSON.stringify(event);
console.info("stringified:");
console.info(eventSTR);
var reISO = /^\d{4}-\d\d-\d\dT\d\d:\d\d:\d\d\.\d+Z$/;
var result = JSON.parse(eventSTR, function (key, value) {
if (typeof value === 'string' && reISO.test(value)) {
var p = value.match(/\d+/g);
return new Date(Date.UTC(p[0],p[1]-1,p[2],p[3],p[4],p[5],p[6]));
}
return value;
});
console.info("parsed:");
console.info(result);stringifyЕсли instanceof Date не работает, то можно проверить наличие метода-прототипа Date:
if (Object(value).getTime) {
return value.getTime();
}
Однако на этапе синтаксического анализа вам будет сложно отличить такие номера эпох от других числовых значений; у вас не было бы точного указания, следует ли преобразовать номер в Date...
Этот ответ работает! Мне пришлось компенсировать разные форматы IE 0-11 за месяц против 1-12 за месяц. Десятикратное спасибо!
@ Энтони — p[1] должен быть p[1] - 1 для всех. Это вещь ECMAScript, а не специфичная для IE.
Можете ли вы обновить ответ, чтобы исправить индекс месяца? Вы не можете использовать спред таким образом, так как месяц все еще нужно уменьшить. :-)
Спасибо за отзыв о месяце. Исправлено.
TLDR В чем именно заключается вопрос? См. Как спросить