Angular v20: stabilizacja reactivity, nowe API i pożegnanie ze strukturalnymi dyrektywami

Angular v20: stabilizacja reactivity, nowe API i pożegnanie ze strukturalnymi dyrektywami

Zespół Angular ogłosił premierę wersji 20, skupiając się na stabilizacji istniejących funkcji, wsparciu dla GenAI, usprawnieniu debugowania oraz dalszym odchodzeniu od Zone.js. Wśród najważniejszych zmian znalazły się nowe eksperymentalne API, rozbudowane wsparcie dla renderowania po stronie serwera oraz aktualizacje stylu i diagnostyki, – informuje Angular Blog.

Stabilne Signals, nowe API i koniec dla *ngIf

Zespół Angular sfinalizował prace nad systemem reaktywności opartym na Signals, który od wersji 16 był dostępny w trybie preview. Obecnie funkcje signal, computed, input oraz view queries uzyskały status stabilny, a dołączyły do nich effect, linkedSignal i toSignal.

Wersja 20 wprowadza również eksperymentalne API oparte na Signals do zarządzania stanem asynchronicznym: resource oraz httpResource. Przykład wykorzystania resource do pobierania danych użytkownika:

const userId: Signal<string> = getUserId();
const userResource = resource({
  params: () => ({id: userId()}),
  loader: ({request, abortSignal}): Promise<User> => {
    return fetch(`users/${request.id}`, {signal: abortSignal});
  },
});

Równolegle wprowadzono nową wersję httpResource, pozwalającą na bezpośrednie wykorzystanie sygnałów w szablonach:

@Component({
  template: `{{ userResource.value() | json }}`
})
class UserProfile {
  userId = signal(1);
  userResource = httpResource<User>(() => 
    `https://example.com/v1/users/${this.userId()}`
  );
}

Zespół ogłosił także formalne rozpoczęcie procesu wycofywania dyrektyw strukturalnych *ngIf, *ngFor i *ngSwitch na rzecz nowej składni wprowadzonej w Angular 17. Przejście na nowy system wspiera komenda:

ng generate @angular/core:control-flow

Zoneless, SSR i ulepszenia DevTools

W Angular v20 tryb zoneless uzyskał status developer preview. Dzięki provideZonelessChangeDetection() i nowemu systemowi obsługi błędów w Node.js oraz przeglądarce możliwe jest działanie bez zależności od biblioteki Zone.js:

bootstrapApplication(AppComponent, {providers: [
  provideZonelessChangeDetection(),
  provideBrowserGlobalErrorListeners()
]});

Wydanie zawiera także stabilną wersję incremental hydration, umożliwiającą stopniowe pobieranie i aktywację komponentów:

@defer (hydrate on viewport) {
  <shopping-cart/>
}

Dodano także obsługę konfiguracji trybu renderowania na poziomie trasy (route-level rendering mode). Dla przykładu:

export const routeConfig: ServerRoute = [
  { path: '/login', mode: RenderMode.Server },
  { path: '/dashboard', mode: RenderMode.Client },
  {
    path: '/product/:id',
    mode: RenderMode.Prerender,
    async getPrerenderParams() {
      const dataService = inject(ProductService);
      const ids = await dataService.getIds();
      return ids.map(id => ({ id }));
    }
  }
];

Zespół Angular wspólnie z Firebase App Hosting przygotował narzędzia do łatwego wdrażania aplikacji SSR, SSG i CSR w chmurze Google Cloud.

Debugowanie, styl i wsparcie dla GenAI

W Angular v20 dodano wsparcie dla profilowania aplikacji bezpośrednio w Chrome DevTools dzięki integracji z Performance Panel. Po uruchomieniu ng.enableProfiling() możliwe jest śledzenie cykli renderowania, detekcji zmian i uruchamiania zdarzeń na wspólnej osi czasu z kodem JavaScript.

Zespół wprowadził również:

  • aktualizacje stylu (brak domyślnych sufiksów klas i plików),
  • pełne wsparcie typów i diagnostyki dla @HostBinding i @HostListener,
  • nowe funkcje do dynamicznego tworzenia komponentów (createComponent, inputBinding, outputBinding),
  • rozszerzenia składni szablonów: **, in, literały szablonowe.

Wprowadzono także eksperymentalne wsparcie dla testów w vitest:

npm i vitest jsdom --save-dev

Wspierając rozwój aplikacji AI, Angular udostępnia plik llms.txt oraz przewodniki na angular.dev/ai. Celem jest zapewnienie zgodności kodu generowanego przez LLM z najnowszą składnią Angulara.

Na zakończenie zespół ogłosił konkurs na oficjalną maskotkę Angulara — propozycje obejmują postać w kształcie logo, a także warianty inspirowane rybą głębinową (anglerfish). Udział w głosowaniu i zgłaszaniu nazw możliwy jest przez formularz RFC.

Avatar
Feb 14

Wydanie języka programowania Go 1.24: Nowości i Optymalizacje

Po sześciu miesiącach intensywnego rozwoju, firma Google we współpracy z community zaprezentowała wydanie języka programowania Go w wersji 1.24. Go, łączące wysoką wydajność języków kompilowanych z zaletami skryptowych języków programowania, takich jak prostota pisania kodu, szybkość rozwoju i ochrona przed błędami, nieustannie ewoluuje. Kod projektu jest dostępny na licencji BSD.
0
Jun 5

Sąd apelacyjny odrzuca wniosek Apple — zmiany w App Store pozostają w mocy

Amerykański Sąd Apelacyjny dla Dziewiątego Okręgu odrzucił wniosek Apple o tymczasowe wstrzymanie decyzji sądu niższej instancji, która nakłada na firmę obowiązek umożliwienia deweloperom kierowania użytkowników do zewnętrznych systemów płatności bez pobierania prowizji. Spółka nie wykazała, że spełnione zostały warunki konieczne do zawieszenia wykonania wyroku,
0
Jun 10

Apple prezentuje Apple Intelligence i nowy wygląd systemów na WWDC 2025

Podczas konferencji WWDC 2025, która odbyła się 9 czerwca, Apple zapowiedziało szereg aktualizacji systemów operacyjnych oraz przedstawiło własny zestaw funkcji opartych na sztucznej inteligencji – Apple Intelligence. Wydarzenie przyniosło największą od lat zmianę w wyglądzie interfejsu oraz szereg nowych funkcji dostępnych na iPhone’ach, iPadach, Macach i Apple Watchach
0

This site uses cookies to offer you a better browsing experience.

Find out more on how we use cookies and how to change cookie preferences in our Cookies Policy.

Customize
Save Accept all cookies