@dmitrytavern/object-parser
- is a library for object validation that takes the original object and its schema, and then checks all object properties for existence and typing, can call a custom validator and assign a default value.
The library supports typescript and has smart autocomplete for checked objects.
It has no external dependencies and weighs ~7KiB compressed without gzip and ~3KiB with.
npm install --save @dmitrytavern/object-parser
import parser from '@dmitrytavern/object-parser' const schema = parser.schema({ name: String, age: [String, Number], role: parser.property({ type: String, required: false, default: 'anonymous', validator: (value) => { if (!['anonymous', 'user', 'admin'].includes(value)) throw new Error('Role must be "anonymous", "user" or "admin".') return true }, }), }) const target = { name: 'Dmitry', age: 19 } const result = parser.parse(target, schema) // => { // value: { name: 'Dmitry', age: 19, role: 'anonymous' } // errors: [] // }
What's going on here:
- Imported parser.
- Created the object schema where:
name
- is required property which can be only String.age
- is required property which can be String or Number.role
- is not required property, which can be only an "anonymous", "user" or "admin" string. Value by default: "anonymous".
- Parsed the target object by the object schema.
The result of parsing is an object, where:
value
- parsed object. By default is a reference on the original object.errors
- array of errors. Сontains parsing errors.
ObjectParser is available via npm:
npm install --save @dmitrytavern/object-parser
Browser/CDN:
<script src="https://unpkg.com/@dmitrytavern/object-parser/dist/object-parser.min.js"></script>
CommonJS:
const parser = require('@dmitrytavern/object-parser') const { parser } = require('@dmitrytavern/object-parser') const { parse, schema, property } = require('@dmitrytavern/object-parser')
ES6:
import parser from '@dmitrytavern/object-parser' import { parser } from '@dmitrytavern/object-parser' import { parse, schema, property } from '@dmitrytavern/object-parser'
Browser:
<script> const parser = window.objectParser const { parser } = window.objectParser const { parse, schema, property } = window.objectParser </script>
You can use the style you prefer. For more information, see docs.
Powerful documentation can be found at dmitrytavern.github.io/object-parser.
MIT - check repo files
Copyright (c) 2022-present, Dmitry Tavern