Die neueste Version 0.9 des Schema Validation Toolkits – ajv-ts bringt eine Reihe von Verbesserungen mit sich, um die Entwicklerproduktivität zu verbessern und eine bessere Validierungsgenauigkeit sicherzustellen. Unabhängig davon, ob Sie komplexe Datenmodelle erstellen oder nur grundlegende Eingaben verarbeiten, helfen diese Updates dabei, Schemadefinitionen mit robusteren Funktionen und Beispielen zu optimieren. Hier finden Sie einen Überblick über die wichtigsten Updates, die in dieser Version eingeführt wurden, zusammen mit einer Zusammenfassung der wesentlichen Änderungen gegenüber Release 0.7.
Eines der wichtigsten Updates in Version 0.9 ist die Einführung von Schemabeispielen für jeden Datentyp. Mit dieser Funktion können Entwickler spezifische Beispiele direkt in ihre Schemadefinitionen einbinden, was für mehr Transparenz und Benutzerfreundlichkeit sorgt. Sie können es auch mit jeder Argumentlänge verwenden.
// Valid examples for a string schema const myString = s.string().examples(["hello", "world"]); myString.schema // // {type: 'string', examples: ['hello', 'world']} s.string().examples("hello", "world"); // OKs
// Valid examples for a number schema const myNum1 = s.number().examples(1, 2, 3); myNum1.schema // {type: 'number', examples: [1,2,3]} // TypeScript error for invalid number types // @ts-ignore fails ts, but schema still ok const myNum2 = s.number().examples(["abc", "123"]); myNum2.schema // {type: "number", examples: ["abc", "123"] }
Diese Änderung hilft bei der Validierung der richtigen Datentypen und verbessert die Dokumentation in Ihrem Code, sodass Teams leichter verstehen können, welche Werte erwartet werden.
Es lohnt sich auch, einige der bedeutenden Änderungen hervorzuheben, die in der vorherigen Version 0.8 eingeführt wurden und eine strengere Zahlenvalidierung mit sich brachten:
s.number().format("float").int(); // Error: incompatible format and type s.number().int().format("double"); // Error: 'double' format not allowed for integers
s.number().min(5).max(3); // Error: max cannot be smaller than min s.number().min(1).max(10).const(15); // Error: constant is out of specified range
Diese Verbesserungen trugen dazu bei, logische Fehler bei der Schemadefinition zu verhindern und sorgten für eine konsistentere Datenvalidierung.
Die Updates Release 0.9 und Release 0.8 verbessern die Entwicklererfahrung erheblich, indem sie bessere Beispiele, strengere Validierung und verbesserte Fehler bieten Handhabung – insbesondere für TypeScript-Benutzer. Diese Funktionen machen die Schemadefinition in komplexen Projekten intuitiver, zuverlässiger und einfacher zu warten. Entdecken Sie unbedingt die neuen Funktionen, um Ihre Validierungsabläufe effizienter zu gestalten!
Link zum Projekt: https://github.com/vitalics/ajv-ts
Das obige ist der detaillierte Inhalt vonAjv-ts bekam . Was ist neu?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!