Fetching data from api with caching
This guide will walk you through the process of creating a basic stale-while-revalidate system using SvelteKit. This technique is particularly useful for improving performance by reducing unnecessary API calls and serving data more quickly.
Understanding the Cache Structure
We'll start by creating a simple cache object:
const cache = {
  data: null,
  lastFetched: 0
};
const CACHE_DURATION = 60 * 1000; // 1 minute in millisecondsThis cache object has two properties:
- data: Stores the cached data
- lastFetched: Timestamp of when the data was last fetched
We also define CACHE_DURATION, which sets how long the cached data remains valid (1 minute in this case).
Implementing the Load Function
Next, we'll create an asynchronous load function that manages the caching logic:
const cache = {
  data: null,
  lastFetched: 0
};
const CACHE_DURATION = 60 * 1000; // 1 minute in milliseconds
export async function load({ setHeaders }) {
  const now = Date.now();
  // Check if we have cached data and it's still fresh
  if (cache.data && now - cache.lastFetched < CACHE_DURATION) {
    // Serve cached data immediately
    return cache.data;
  }
  // Fetch fresh data
  const freshData = await fetchDataFromAPI();
  // Update cache
  cache.data = freshData;
  cache.lastFetched = now;
  // Set cache headers
  setHeaders({
    'Cache-Control': `max-age=0, s-maxage=${CACHE_DURATION / 1000}, stale-while-revalidate`
  });
  return freshData;
}This function does the following:
- Checks if cached data exists and is still fresh 
- If cache is valid, returns cached data immediately 
- If cache is invalid or doesn't exist, fetches fresh data from the API 
- Updates the cache with fresh data 
- Sets appropriate cache headers 
- Returns the fresh data 
The setHeaders function is framework-specific. Ensure your setup supports this method or adjust accordingly.
Fetching Data from the API
The fetchDataFromAPI function is responsible for making the actual API call:
// Rest of code
async function fetchDataFromAPI() {
  const response = await fetch('https://admin.shentohendriks.nl/items/projects');
  const json = await response.json();
  return json;
}This function fetches data from a specific API endpoint and returns the parsed JSON response.
Using the Cached Data in a Svelte Component
Finally, let's look at how to use this cached data in a Svelte component:
<script>
  export let data;
</script>
<img src={`https://admin.shentohendriks.nl/assets/${data.data[0].featuredImage}?key=compression`} alt="">This Svelte component receives the data prop, which contains the cached or freshly fetched data. It then uses this data to display an image.
Conclusion
This simple in-memory caching system can significantly improve your application's performance by reducing unnecessary API calls. Remember to adjust the cache duration and error handling to suit your specific needs.
While this example uses in-memory caching, for larger applications or server-side caching, consider using more robust caching solutions like Redis or Memcached.
Last updated