angular-signals
Angular Signals
Version: Angular 16+ (2025) Tags: Reactivity, State Management, Signals API
References: Angular Signals • API Reference
API Changes
This section documents version-specific API changes.
-
NEW: Angular 19 Resource API — New way to handle async data with built-in loading/error states
-
NEW: linkedSignal() — Creates a signal linked to external sources with getter/setter source
-
NEW: Signal inputs — Use
input()andinput.required()for reactive component inputs -
NEW:
toSignal()andtoObservable()— Bridge between RxJS and Signals -
NEW:
effect()improvements — Better cleanup withonCleanupcallback -
NEW: Zoneless change detection — Works seamlessly with Signals
Best Practices
- Use
computed()for derived state — Never useeffect()for deriving values
// ✅ DO THIS - derived state
totalPrice = computed(() => {
return this.items().reduce((sum, item) => sum + item.price, 0);
});
// ❌ DON'T - side effects in computed
badComputed = computed(() => {
const data = this.data();
this.logService.log(data); // Side effect - don't do this!
});
- Use
signal()for writable state
count = signal(0);
// Update with set()
count.set(5);
// Update with update()
count.update(value => value + 1);
// Update with mutate() for objects
user.update(u => ({ ...u, name: 'New Name' }));
- Use
effect()only for side effects
effect(() => {
analytics.track('cart-updated', {
itemCount: this.items().length
});
});
- Always cleanup effects to prevent memory leaks
effect((onCleanup) => {
const timer = setTimeout(() => { /* ... */ }, 300);
onCleanup(() => clearTimeout(timer));
});
- Use Signal Inputs instead of traditional @Input()
// Modern signal inputs (Angular 17+)
userId = input<string>('');
user = input.required<User>();
// Computed based on input
greeting = computed(() => `Hello, ${this.user()?.name}`);
- Use
toSignal()for RxJS to Signal conversion
// Convert Observable to Signal
users = toSignal(this.http.get('/api/users'), { initialValue: [] });
-
Don't nest effects — Can cause performance issues
-
Use equality functions for complex object comparisons
user = signal<User | null>(null, {
equal: (a, b) => a?.id === b?.id
});
- Use Signals for UI state, RxJS for complex async — Signals and RxJS serve different purposes
More from oguzhan18/angular-ecosystem-skills
angular-tailwind
ALWAYS use when working with Angular and Tailwind CSS, Tailwind configuration, utility-first CSS, or styling Angular applications with Tailwind.
139angular-animations
>-
137rxjs
ALWAYS use when working with RxJS Observables, operators, and reactive patterns in Angular applications.
135angular-material
ALWAYS use when working with Angular Material components, CDK, or Material Design in Angular applications.
131angular-security
ALWAYS use when working with Angular Security, XSS prevention, CSRF protection, Content Security Policy, or sanitization in Angular applications.
130angular-bootstrap
ALWAYS use when working with Angular Bootstrap, ng-bootstrap, Bootstrap components in Angular, or Bootstrap 5 integration.
129