
Security News
Oracle Drags Its Feet in the JavaScript Trademark Dispute
Oracle seeks to dismiss fraud claims in the JavaScript trademark dispute, delaying the case and avoiding questions about its right to the name.
json-api-normalize
Advanced tools
A simple way to traverse datasets based on JSON API specification. Normalize is a lightweight javascript library with simple and powerful api. Has no dependencies and weighs less than 1KB.
"If you’ve ever argued with your team about the way your JSON responses should be formatted, JSON API can be your anti-bikeshedding tool." If you are new to JSON api we recommend you browse json api website and examples to familiarize yourself with specification. This library is built upon standards and conventions of JSON api and provides a simple way to traverse and retrieve all those attributes and relations.
Lets start with a typical JSON api formatted dataset:
articleJsonApiData = {
data: {
type: 'article',
id: '1',
attributes: {
title: 'JSON API paints my bikeshed!',
body: 'The shortest article. Ever.'
},
relationships: {
author: {data: {id: '42', type: 'user'}},
publisher: {data: {id: '24', type: 'user'}},
tags: {data: [
{id: '1', 'type': 'tag'},
{id: '2', 'type': 'tag'}
]}
}
},
included: [{
type: 'user',
id: '42',
attributes: {
firstName: 'John',
lastName: 'Doe',
},
relationships: {
boss: {'data': {'id': '42', 'type': 'user'}},
}
}, {
type: 'tag',
id: '1',
attributes: {
name: 'tag 1'
}
}, {
type: 'tag',
id: '2',
attributes: {
name: 'tag 2'
}
}]
};
Using JSON api normalize we can retrive simple data like so:
normalize(articleJsonApiData).get('title');
// will return 'JSON API paints my bikeshed!
normalize(articleJsonApiData).get('author.firstName');
// will output 'John'
normalize(articleJsonApiData).get(['id', 'title', 'body']);
// will return
// {
// id: '1',
// title: 'JSON API paints my bikeshed!',
// body: 'The shortest article. Ever.'
// }
Next example shows how to retrieve complex dataset that can include (circular) relation data:
normalize(articleJsonApiData).get([
'id',
'title',
'body',
'author.id',
'author.firstName',
'author.lastName',
'author.boss.firstName',
'author.boss.lastName',
'tags.id',
'tags.name',
]);
// will return
// {
// id: '1',
// title: 'JSON API paints my bikeshed!',
// body: 'The shortest article. Ever.',
// author: {
// id: '42',
// firstName: 'John',
// lastName: 'Doe',
// boss: {
// firstName: 'John',
// lastName: 'Doe'
// }
// },
// tags: [{
// id: '1',
// name: 'tag 1'
// }, {
// id: '2',
// name: 'tag 2'
// }]
// };
Json api normalize is packaged as UMD library so you can use it both on client and server (CommonJS and AMD environment) or with browser globals.
// install via npm
npm install json-api-normalize --save
// if you use bundler
var normalize = require('json-api-normalize');
// or just using browser globals
var normalize = window.jsonApiNormalize;
FAQs
Normalize JSON api dataset
We found that json-api-normalize demonstrated a not healthy version release cadence and project activity because the last version was released a year ago. It has 1 open source maintainer collaborating on the project.
Did you know?
Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.
Security News
Oracle seeks to dismiss fraud claims in the JavaScript trademark dispute, delaying the case and avoiding questions about its right to the name.
Security News
The Linux Foundation is warning open source developers that compliance with global sanctions is mandatory, highlighting legal risks and restrictions on contributions.
Security News
Maven Central now validates Sigstore signatures, making it easier for developers to verify the provenance of Java packages.