What is Superactions?
Superactions is a small library built around the API routes functionality in SvelteKit.
It allows you to easily and type safely call your server-side code from the client, while mostly utilising the existing functionality and patterns of SvelteKit.
Why?
SvelteKit's load functions and forms actions cover most normal use cases around data loading and submitting. Still, there are sometimes cases where these tools become either clunky or impractical to use.
Here are some concrete examples:
- Games* or other interactive apps that don't use forms for interaction
- Stores or reactive classes that call the server from normal
.js
/.ts
files
*Fast-paced games probably shouldn't use HTTP for communication
Should I use this library?
While I do think you should try Superactions out (totally unbiased opinion 😉), it's best if you're also aware of its strengths and weaknesses.
🚫 When you cannot use Superactions:
- The app has to work without JavaScript (try form actions)
🤷 When you might not need Superactions:
- You can use load functions
- You can use URL parameters to specify what data to load
- Data submissions can be done using form elements (try Superforms!)
👍 When using Superactions can benefit you:
- The data you're sending is too complex to be represented as FormData (and maybe you don't like embedding JSON inside FormData)
- Using form elements or URL parameters to submit the data isn't easy or practical
- You want automatic type safety for your server calls
- Your data is JSON only (with some additions)
Shout-outs
Thanks to:
- React Server Actions for guiding the developer experience
- Superforms for influencing the name and initial implementation