ITNEXT

ITNEXT is a platform for IT developers & software engineers to share knowledge, connect, collaborate, learn and experience next-gen technologies.

Follow publication

Member-only story

Having fun deconstructing the ​localstorage in TypeScript 🤙

David Dal Busco
ITNEXT
Published in
3 min readSep 1, 2022

--

Photo by Katya Ross on Unsplash

I recently implemented some features with the localstorage. While I always had read values using the getItem() method of the interface, I replaced this approach in my recent work with deconstruction of the storage object.

For no particular reason. I just like to deconstruct things, a lot 😄.

Old school

​Back in the days — until last few weeks 😉 — I would have probably implemented a function to read a stringified object​ from the storage as following:

type MyType = unknown;

const isValid = (value: string | null): value is string => [null, undefined, ""].includes(value)

const oldSchool = (): MyType | undefined => {
const value: string | null = localStorage.getItem("my_key");

if (!isValid(value)) {
return undefined;
}

return JSON.parse(value);
};

​i.e. I would have first get the string​ value (stringified JSON.stringify() representation of the object I would have saved in the storage) using getItem()​ before double checking its validity and parsing it back to an object.

New school

​While I nowadays keep following previous logic (“read, check validity and parse”), I am now deconstructing the storage to read the value.

const newSchool = (): MyType | undefined => {
const { my_key: value }: Storage = localStorage;

if (!isValid(value)) {
return undefined;
}

return JSON.parse(value);
};

Again, no particular reason but, isn’t it shinier? 👨‍🎨

This approach is possible in TypeScript because the ​Storage​ interface — representing the Storage API — is actually declared as a map of keys of any​ types.

interface Storage {
readonly length: number;
clear(): void;
getItem(key: string): string | null;
key(index: number): string | null;
removeItem(key: string): void;
setItem(key: string, value: string): void;
// HERE 😃 [name: string]: any;
[name: string]: any;
}

SSR & pre-rendering

The localstorage is a readonly property of the window​ interface — i.e. it exists only in the browser. To prevent my SvelteKit’s static build to crash when I use it, I set…

--

--

Published in ITNEXT

ITNEXT is a platform for IT developers & software engineers to share knowledge, connect, collaborate, learn and experience next-gen technologies.

No responses yet