Use SignalDB in Angular
This guide will show you how to incorporate SignalDB into your Angular app, including setting up collections and using SignalDB’s reactive features within Angular components.
Requirements
Before we begin, ensure you have a basic understanding of Angular and an existing Angular project ready. If not, refer to the Angular Tutorial.
It’s also helpful to be familiar with signal-based reactivity. You can learn more about this in the Core Concepts section and explore Angular Signals to see how reactivity is handled in the framework.
Installing SignalDB
To begin, install SignalDB by running this command in your terminal:
npm install signaldb
Next, install the Angular-specific reactivity adapter for SignalDB:
npm install signaldb-plugin-angular
Setting Up SignalDB
With SignalDB installed, you’ll now set up a collection and configure the reactivity adapter for Angular:
import { Collection } from 'signaldb';
import angularReactivityAdapter from 'signaldb-plugin-angular';
const Posts = new Collection<{ id: string, title: string, author: string }>({
reactivity: angularReactivityAdapter,
});
In this example, we define a Posts
collection and use the Angular reactivity adapter to enable seamless updates in your Angular components.
Building an Angular Component
Let’s now create an Angular component that uses SignalDB to display and manage a list of posts:
import { Component, effect } from '@angular/core';
import { RouterOutlet } from '@angular/router';
import { Collection } from 'signaldb';
import angularReactivityAdapter from 'signaldb-plugin-angular';
const Posts = new Collection<{ id: string, title: string, author: string }>({
reactivity: angularReactivityAdapter,
});
@Component({
selector: 'app-root',
standalone: true,
imports: [RouterOutlet],
template: `
<ul>
<li><button (click)="insertPost()">Add Post</button></li>
@for (item of items; track item.title) {
<li>{{item.title}} ({{item.author}})</li>
}
</ul>
`,
})
export class AppComponent {
items: {id: string, title: string, author: string}[] = [];
insertPost() {
Posts.insert({ title: 'Post 1', author: 'Author 1' });
}
constructor() {
effect((onCleanup) => {
const cursor = Posts.find();
this.items = cursor.fetch();
onCleanup(() => {
cursor.cleanup();
});
});
}
}
Key Concepts:
- Collection Setup: We create a
Posts
collection withsignaldb-plugin-angular
to enable reactivity. - Component Overview: The
AppComponent
uses Angular’seffect()
to automatically update theitems
array whenever thePosts
collection changes. - Rendering in Template: The template renders a list of posts using an
@for
loop, and theinsertPost()
method adds a new post when the "Add Post" button is clicked. - Effect Hook: The
effect()
function handles reactivity, ensuring the component stays in sync with changes in thePosts
collection. The cleanup function removes the cursor when the component is destroyed.
Wrapping Up
You have now successfully integrated SignalDB into an Angular app and created a reactive component to display and manage posts. With this setup, you can leverage SignalDB’s reactive capabilities to handle data updates and synchronization in your Angular application.
Next Steps
Now that you’ve learned how to use SignalDB in Angular, you maybe want to explore the possibilities how you can synchronize the data with your backend. Take a look at the Synchronization Overview to get started