JavaScript utilizza il metodo statico parse della classe JSON per parsare una stringa JSON e trasformarla in un oggetto. Questo metodo analizza anche il tipo del campo (numero, stringa booleano) creando poi una proprietà dello stesso tipo quando crea l'oggetto. Questo discorso non vale però per le date in quanto queste vengono serializzate come stringhe e quindi il parser le tratta come tali quando va a creare l'oggetto. Tuttavia possiamo personalizzare il comportmento di JSON.parse passando in input non solo la stringa JSON, ma anche un callback che il metodo invoca per ogni proprietà. Il callback accetta in input la proprietà e deve restituire in output il controvalore che verrà aggiunto nell'oggetto. Sfruttando questo callback possiamo analizzare il valore dei campi di tipo string e se hanno il formato della data possiamo trasformarli in un oggetto Date di JavaScript e restituirlo.
JSON.parse(json, callback); callback(key, value) { // se non è una stringa torna il valore originale if (typeof value !== 'string') { return value; } // se ha il formato di una data ma è al valore minimo consentito torna null if (value === '0001-01-01T00:00:00') { return null; } // se non ha il formato di una data torna il valore originale const match = /^(\d{4})-(\d{2})-(\d{2})T(\d{2}):(\d{2}):(\d{2}(?:\.\d*)?)Z$/.exec(value); if (!match) { return value; } // se ha il formato di una data crea l'oggetto date e lo torna return new Date(value); }
Commenti
Per inserire un commento, devi avere un account.
Fai il login e torna a questa pagina, oppure registrati alla nostra community.
Approfondimenti
Usare le variabili per personalizzare gli stili CSS
Usare lo spread operator con i collection initializer in C#
Sfruttare al massimo i topic space di Event Grid MQTT
Eseguire attività pianificate con Azure Container Jobs
Sfruttare MQTT in cloud e in edge con Azure Event Grid
3 metodi JavaScript che ogni applicazione web dovrebbe contenere - Parte 2
Ottenere il contenuto di una cartella FTP con la libreria FluentFTP
Gestire liste di tipi semplici con Entity Framework Core
Effettuare lo stream della risposta in ASP.NET Core tramite IAsyncEnumerable
Creare un'applicazione React e configurare Tailwind CSS
Sviluppare un'interfaccia utente in React con Tailwind CSS e Preline UI
Utilizzare Model as a Service su Microsoft Azure
I più letti di oggi
- Evitare il flickering dei componenti nel prerender di Blazor 8
- Rilasciata la Beta 2 di Visual Studio 2008
- tra pochi minuti inizia la keynote della seconda giornata. seguila live su http://aspitalia.com/mix-11 #mix11
- .@dbochicchio ora su #aspnetcore 2 a #netconfit https://aspit.co/netconf-17
- Utilizzare angular-cli per creare una direttiva in Angular 2
- Windows Vista: il ritorno di WinFS con la beta1
- .@CristianCivera tra poco su #azure con i suoi tips&tricks per lo sviluppatore web: https://aspit.co/web15-live #aspilive
- Le novità di C# 10