3 KiB
Astro Resume
Utilities for serializing data from server for use in the client.
Serialize
Astro component takesid
anddata
deserialize(id: string)
function for use int he client takes anid
string and returns thedata
Installation & Examples
Install via npm
On your Astro project:
npm i @ayco/astro-resume
Usage
Serializing and deserializing basic primitive data
---
import Serialize from "@ayco/astro-resume";
const data = {
hello: 'world',
}
---
<Serialize id="my-data" data={data} />
<script>
import {deserialize} from '@ayco/astro-resume';
const data = deserialize('my-data');
console.log(data) // {hello: 'world'}
</script>
Type Safety
You can define a type for the data and use it in the client script.
---
import Serialize from "@ayco/astro-resume";
const data = {
hello: 'world',
isOkay: true
}
// define the type of data to be serialized
export type Data = typeof data;
---
<Serialize id="my-data" data={data} />
<script>
import {deserialize} from '@ayco/astro-resume';
/**
* reuse the type in the client
* assuming this component's name is `ThisComponent.astro`
*/
import type {Data} from './ThisComponent.astro';
const data = deserialize<Data>('my-data');
console.log(data) // {hello: 'world', isOkay: true}
</script>
Passing all Astro.props to client
If you need to make all the component props to the client script:
---
import Serialize from "@ayco/astro-resume";
export interface Props {
hello: string;
isOkay: boolean;
}
---
<Serialize id="preferences" data={{...Astro.props}} />
<script>
import {deserialize} from '@ayco/astro-resume';
import type {Props} from './ThisComponent.astro';
const {hello, isOkay} = deserialize<Props>('preferences');
console.log(hello, isOkay);
</script>
What's happening here?
This is a quick and easy pattern to embed serialized information into your HTML and make it available in the client-side script.
The Serialize
component will write the data as JSON wrapped in a <script type="application/json">
element to hold the string.
The deserialize()
function can then parse the value string for use in your client script.
There is also a pattern given in the Astro docs to use a Custom Element that takes a data-
prop which properly protects the scope of your component. That is a good pattern to follow for complex applications that don't use UI frameworks.
Trade-Off
You have to manage the IDs yourself (i.e., make sure they are unique) and understand that the deserialize()
function will crawl the whole document incurring a minimal performance cost depending on how big your HTML is.
Reporting Issues
To report issues or request features, send a plain text email to ~ayoayco/astro-resume@todo.sr.ht or file a ticket via SourceHut