Unlock the Power of Svelte: A Modern Frontend Library

The latest “State of JavaScript” survey reveals that Svelte is the frontend library to watch in 2020, thanks to its modern style and simplicity. As a modern reactive component framework, Svelte runs at build time, converting components into highly efficient imperative code that surgically updates the DOM.

Building a Simple App with Svelte and API

In this article, we’ll explore how Svelte consumes and renders data from an API by building a simple app. We’ll create a backend to store our data and then write our Svelte components. Assuming you have a basic understanding of JavaScript, CSS, Node.js, and Svelte, let’s dive in!

Setup and Installation

To get started, we’ll set up a working directory for our application using degit, a scaffolding tool to clone a Svelte template. Run the following command in your terminal:

npx degit sveltejs/template continent-app

Next, navigate into the newly created directory and install the dependencies:

cd continent-app
npm install

Create two component files, Continents and Continent, and start the app:

npm run dev

You should see the default landing page.

Building the API

Our API is a simple one that holds hardcoded information about the seven continents. Create a new folder api in the app’s directory and install the required dependencies:

cd api
npm init -y
npm install express body-parser

Create a new file app.js that will hold the simple backend:
“`javascript
const express = require(‘express’);
const bodyParser = require(‘body-parser’);

const app = express();
app.use(bodyParser.json());

const continents = [
{ name: ‘Africa’, population: 1234, countries: 56, area: 30000000 },
{ name: ‘Asia’, population: 4567, countries: 78, area: 44000000 },
//…
];

app.get(‘/api/continents’, (req, res) => {
res.json(continents);
});

app.listen(8081, () => {
console.log(‘Server started on port 8081’);
});

Start the backend with the command:

node app.js

You should see a running message, and navigating to
localhost:8081` returns a list of continents and their data.

Writing the Svelte Components

Now that we have our backend up and running, let’s write our Svelte components to retrieve and render the data. We’ll write two components: Continent and Continents.

Continent Component

The Continent component renders the data of a continent passed as a prop to it from the Continents component.
“`svelte

{continent.name}

Population: {continent.population}

Countries: {continent.countries}

Area: {continent.area} km²

“`
Continents Component

The Continents component retrieves the list of continents from the backend and renders them through the Continent component.
“`svelte

{#if continents.length > 0}
{#each continents as continent}

{/each}
{:else}

Loading…

{/if}

“`
Rendering the App

We’ve successfully written the components, and now it’s time to render the data via the app’s main component. Rewrite the App component:
“`svelte




Start the app with the command:

npm run dev
“`
You should see the rendered data from the API.

What’s Next?

In this article, we’ve explored how to consume and render data from a backend in Svelte, define and export props, and pass props to components. We’ve also briefly looked at the onMount() method. With Svelte’s built-in template system, building simple apps has never been easier. Happy coding!

Leave a Reply