Package Exports
This package does not declare an exports field, so the exports above have been automatically detected and optimized by JSPM instead. If any package subpath is missing, it is recommended to post an issue to the original package (json-as) to support the "exports" field. If that is not possible, create a JSPM override to customize the exports field for this package.
Readme
AS-JSON
JSON serializer/deserializer for AssemblyScript
Installation
~ npm install json-as
~ npm install visitor-as
Add the transform to your asc
command
--transform json-as/transform
Or, add it to asconfig.json
{
"options": {
"transform": "json-as/transform"
}
}
Support
- ✅ Objects (Supported)
- ✅ Arrays (Supported)
- ✅ Numbers (Supported)
- ✅ Integers (Supported)
- ✅ Null (Supported)
- ❌ Dynamic Variants (Not supported)
Usage
import { JSON } from "json-as";
@json
class Vec2 {
x: f32
y: f32
}
@json
class Player {
firstName: string
lastName: string
lastActive: i32[]
age: i32
pos: Vec2
isVerified: boolean
}
const data: Player = {
firstName: "Emmet",
lastName: "West",
lastActive: [8, 27, 2022],
age: 23,
pos: {
x: -3.4,
y: 1.2
},
isVerified: true
}
const stringified = JSON.stringify<Player>(data);
// {
// "firstName": "Emmet",
// "lastName": "West",
// "lastActive": [8, 27, 2022],
// "age": 23,
// "pos": {
// "x": -3.4000000953674318,
// "y": 1.2000000476837159
// },
// "isVerified": true
// }
console.log(`Stringified: ${stringified}`);
const parsed = JSON.parse<Player>(stringified);
// Player {
// firstName: "Emmet",
// lastName: "West",
// lastActive: [8, 27, 2022],
// age: 23,
// pos: {
// x: -3.4000000953674318,
// y: 1.2000000476837159
// },
// isVerified: true
// }
console.log(`Parsed: ${JSON.stringify(parsed)}`);
FAQ
- Does it support the full JSON spec? Yes, as-json supports the full JSON specification and trys to mimic the JSON API as much as possible
- What are the differences between as-json and the JSON API? The main difference between as-json and the JSON API is the ability to create new fields in objects during runtime. Since classes are static, Map ser/de support will be added soon allowing the user to parse and stringify dynamic objects and their properties
- Does this support nested structures? Yes, as-json supports nested structures
- Does this support whitespace? Yes, as-json supports whitespace!
- How fast is it? Really fast. For example, here are some benchmarks for ser/de a Vec2 with as-json
Issues
Please submit an issue to https://github.com/JairusSW/as-json/issues if you find anything wrong with this library