Angular: o que é, para que serve e um Guia para iniciar no framework JavaScript

Angular: o que é, para que serve e um Guia para iniciar no framework JavaScript
Nayanne Batista
Nayanne Batista

Compartilhe

O que é Angular?

Angular é um framework de código aberto desenvolvido pelo Google para a criação de aplicativos dinâmicos e interativos da web.

Ele se baseia em TypeScript, uma linguagem superset do JavaScript, e utiliza uma abordagem orientada a componentes para a construção de interfaces. O Angular oferece uma estrutura sólida para desenvolvimento, incluindo suporte a gerenciamento de estado, roteamento, validação de formulários e muito mais.

Além disso, sua arquitetura modular e o poderoso sistema de injeção de dependência facilitam a manutenção de aplicações complexas.

Veja também:

Banner promocional da Alura, com um design futurista em tons de azul, apresentando o texto

O que é Angular JS?

O Angular é um framework consolidado que foi desenvolvido pela equipe do Google em 2010. Essa primeira versão era conhecida como Angular JS, mas também podemos encontrar a grafia Angular.JS. Desde então, passou por diversas mudanças e evoluções.

A mais importante delas foi a ocorrida em 2016, quando o framework foi praticamente reescrito, modificando sua estrutura e abordagem, passando a ser chamado apenas de Angular 2.0 ou Angular 2+ no caso das versões posteriores.

Para compreender melhor a história e diferenças entre Angular e AngularJS, recomendamos que assista ao vídeo O que é Angular e AngularJS? | #HipstersPontoTube

Por que usar Angular?

O Angular é o framework escolhido por muitas empresas e pessoas desenvolvedoras devido à sua robustez e conjunto de recursos abrangente. Sua estrutura modularizada promove a reutilização de código e a manutenção mais fácil.

Além disso, ele traz poderosas ferramentas para lidar com tarefas complexas, como:

  • Gerenciamento de estados;
  • Manipulação de formulários; e
  • Roteamento.

O uso do TypeScript como linguagem base proporciona tipagem estática e segurança, enquanto a forte comunidade e a documentação extensa facilitam a aprendizagem e o suporte contínuo. Sua integração com bibliotecas como o RxJS para gerenciar fluxos de dados e o Angular Material para criar interfaces atraentes o torna uma solução completa para o desenvolvimento web moderno.

Angular x React

O angular é tão completo que é considerado uma verdadeira plataforma de desenvolvimento. Ele serve para a criação de aplicações de página única, as famosas Single Page Aplications (SPA’s), assim como outros frameworks como React e Vue, com algumas diferenças.

Uma delas é que o React é, na verdade, uma biblioteca e necessita da inclusão de outras bibliotecas para a construção das SPA’s. Já o Angular é um framework e possui todos os recursos necessários para o desenvolvimento.

Saiba mais a respeito dessa batalha no Front-end e acesse o artigo sobre Angular Vs React Vs Vue.

Angular CLI

O angular possui uma interface de linha de comando (CLI) que facilita bastante o desenvolvimento de um novo projeto, simplificando a criação, compilação e implantação de aplicativos.

Com ela não é mais necessário se preocupar com a criação de toda a estrutura de pastas e arquivos de configuração; pois com apenas um comando no terminal, todos esses pacotes são criados e toda a estrutura para começar a desenvolver a sua aplicação estará pronta.

Se você quer entender como criar um novo projeto em Angular utilizando a CLI e entender para que servem os arquivos criados, acesse:

Pré requisitos

Para começar a utilizar o Angular, você já deve ter conhecimentos sobre:

É importante também já ter alguma familiaridade com TypeScript (TS), pois o Angular utiliza essa linguagem por padrão. O TS é um superset do JS, ou seja, possui todas as funcionalidades do JS e acrescenta outras, entre elas, o destaque é para a tipagem.

Leia o artigo Como começar com Angular e obtenha mais informações sobre como iniciar seus estudos com o framework.

Confira também a apostila Desenvolvimento web com HTML, CSS E JavaScript.

TypeScript no Angular

O TypeScript desempenha um papel crucial no desenvolvimento Angular. Ele adiciona recursos de tipagem estática ao JavaScript, tornando o código mais seguro e legível.

O TypeScript oferece as seguintes vantagens:

  • Facilita a detecção de erros em tempo de desenvolvimento;
  • Aprimora a manutenção do código; e
  • Oferece suporte a recursos avançados, como classes, interfaces e enums.

Além disso, o Angular CLI gera automaticamente projetos em TypeScript, simplificando a configuração inicial. TypeScript é totalmente compatível com o Angular; sua integração fluida, suporte da comunidade e recursos modernos o tornam uma opção poderosa para criar aplicativos web escaláveis e estruturados.

Acesse as formações Aplique TypeScript no front-end e Melhore sua experiência de desenvolvimento com TypeScript e conheça o poder dessa linguagem.

Componentes

O angular é baseado em componentes, ou seja, com ele criamos o projeto dividindo-o em pequenas partes, que são reutilizáveis e, juntas, compõem a aplicação. No angular, um componente é formado por 3 partes principais:

  • 1 arquivo de estilo com extensão CSS ou SCSS;
  • 1 arquivo HTML, também chamado de template; e
  • 1 arquivo TypeScript, que contém o comportamento do componente.

Além disso, ao criar o componente através da CLI do angular, também é criado por padrão um arquivo de testes dentro da pasta do componente, com alguns testes unitários.

Veja este artigo e entenda como funciona um componente no Angular.

Ciclo de vida

Os componentes no Angular possuem ciclo de vida, ou seja, eles são inicializados, renderizados, sofrem mudanças e são destruídos.

Entender quando cada evento é acionado e como usá-lo pode ser fundamental para garantir o comportamento adequado e a eficiência de seus componentes. Acesse o curso e conheça mais sobre os hooks do ciclo de vida de componentes angular.

Data binding

O data binding é um recurso central no Angular que permite a sincronização automática de dados entre o modelo de um componente e a sua exibição no template HTML.

Ele simplifica a manipulação e a atualização de dados, tornando a interface mais dinâmica e responsiva.

No one-way binding, os dados fluem apenas do componente para o template ou do template para o componente, garantindo que a interface reflita o estado atual do modelo de dados.

Já no two-way data binding, os dados fluem em ambas as direções, permitindo que as mudanças no template atualizem automaticamente o modelo e vice-versa.

Isso é particularmente útil em formulários, onde os valores de entrada podem ser atualizados em tempo real.

Diretivas

As diretivas no Angular são marcadores em um elemento DOM para:

  • Adicionar um determinado comportamento a esse elemento; ou
  • Modificar sua aparência.

Elas são uma parte fundamental da estrutura do Angular e são usadas para estender o HTML com novos atributos e comportamentos personalizados, servindo para gerenciar formulários, listas, estilos e tudo o que as pessoas visualizam.

Existem dois tipos principais de diretivas no Angular:

  • Diretivas Estruturais;
  • Diretivas de Atributo.

1) Diretivas Estruturais

Diretivas Estruturais alteram a estrutura do DOM, adicionando ou removendo elementos. Exemplos de diretivas estruturais incluem ngIf e ngFor:

  • ngIf: esta diretiva permite que você mostre ou oculte um elemento com base em uma condição;
  • ngFor: usada para repetir elementos com base em uma coleção de dados.

A partir da versão 17 do Angular, a sintaxe das diretivas foi modificada. Assim, as diretivas ngIf e ngFor se tornaram @if e @for. Caso queira aprender a utilizar essa abordagem da versão 17, confira o artigo Novidades no Angular 17.

2) Diretivas de Atributo

Diretivas de Atributo alteram a aparência ou o comportamento de um elemento DOM existente. Exemplos de diretivas de atributo incluem ngClass, ngStyle e ngModel:

  • ngClass: permite adicionar ou remover classes CSS com base em uma condição;
  • ngStyle: usada para definir estilos CSS dinamicamente com base em valores no componente;
  • ngModel: é usada para estabelecer ligação bidirecional entre um elemento de entrada de formulário HTML e uma propriedade do componente.

Esses são apenas alguns exemplos de diretivas no Angular. As diretivas permitem que você crie aplicativos mais dinâmicos e interativos, adicionando lógica ao seu HTML sem poluir seu código com manipulação de DOM diretamente em JavaScript.

Veja neste curso como criar uma diretiva personalizada: Angular: formulários orientados a templates.

Serviços

Um serviço é uma classe no Angular que é projetada para realizar uma tarefa específica ou fornecer funcionalidades compartilhadas em toda a aplicação, como fazer solicitações HTTP, gerenciar estados ou fornecer utilitários.

Os serviços são ideais para encapsular lógica de negócios que precisa ser compartilhada entre componentes, como a autenticação da pessoa usuária, armazenamento de dados ou serviços de terceiros.

Você pode criar um serviço usando o comando ng generate service nome-do-service no Angular CLI ou simplesmente criando uma classe TypeScript e decorando-a com o @Injectable() para torná-la um serviço injetável.

Injeção de Dependências

A injeção de dependências é um padrão de projeto que permite que os componentes recebam as dependências de que precisam (como serviços) em vez de criá-las internamente. Isso torna o código mais:

  • Modular;
  • Reutilizável; e
  • Fácil de testar.

O Angular possui um injetor de dependências que gerencia a criação e a distribuição de instâncias de serviços para os componentes que os solicitam. Quando um componente precisa de um serviço, ele declara o serviço como um parâmetro no construtor e o Angular cuida da criação e da injeção da instância apropriada.

Veja este artigo e aprenda mais sobre services e injeção de dependências.

Comunicação com Servidor

A comunicação com o servidor no Angular ocorre principalmente por meio de solicitações HTTP. O Angular fornece um conjunto de módulos e classes que facilitam a busca e o envio de dados.

Antes de realizar solicitações HTTP, você precisa importar o módulo HttpClientModule na sua aplicação para poder usar o serviço HttpClient fornecido pelo Angular.

Aqui está um exemplo de um serviço que realiza uma solicitação GET:

import { Injectable } from '@angular/core';
import { HttpClient } from '@angular/common/http';
import { Observable } from 'rxjs';

@Injectable({
  providedIn: 'root'
})
export class DataService {
  private apiUrl = 'https://exemplo.com/api'; // URL da API

  constructor(private http: HttpClient) {}

  getData(): Observable<any> {
    return this.http.get<any>(`${this.apiUrl}/endpoint`);
  }
}

Em componentes ou outros serviços, você pode injetar o serviço HttpClient e usar seus métodos, como get(), post(), put(), delete(), etc., para realizar solicitações HTTP.

Por exemplo, para realizar uma solicitação GET:

import { Component, OnInit } from '@angular/core';
import { DataService } from './data.service';

@Component({
  selector: 'app-example',
  template: '<button (click)="fetchData()">Fetch Data</button>',
})
export class ExampleComponent implements OnInit {
  constructor(private dataService: DataService) {}

  ngOnInit() {}

  fetchData() {
    this.dataService.getData().subscribe((data) => {
      // Manipule os dados recebidos aqui
    });
  }
}

A comunicação com o servidor é assíncrona e, no Angular, o uso de Observables é uma prática comum para gerenciar a assincronicidade.

Formulários e validação

Nas aplicações web, os formulários desempenham um papel fundamental na interatividade e experiência de uso.

Os formulários permitem:

  • Coletar informações;
  • Validar entradas; e
  • Tomar decisões com base nos dados fornecidos.

No angular, existem dois tipos principais de formulários:

  • Formulários Orientados a Template; e
  • Formulários reativos.

Nos formulários orientados a template, a lógica e a validação são definidas diretamente no template HTML usando diretivas como ngModel. É uma escolha mais simples e rápida para formulários básicos.

Já os formulários reativos oferecem um alto nível de controle e flexibilidade. Eles são construídos programaticamente no TypeScript usando objetos como FormGroup e FormControl, o que permite uma validação mais avançada e tratamento de formulários complexos.

A escolha entre as abordagens depende da complexidade do seu formulário e dos requisitos de validação.

Veja como aplicar validação em formulários reativos no angular.

Módulos

Um módulo no Angular é um mecanismo para organizar o código do aplicativo em blocos funcionais independentes e reutilizáveis. Cada módulo contém:

  • Componentes;
  • Diretivas;
  • Serviços; e
  • Outros recursos relacionados.

Cada módulo é definido em um arquivo TypeScript separado que contém metadados específicos, como os componentes e serviços que ele declara, bem como outras informações de configuração.

Propósitos dos Módulos

    1. Organização;
    1. Escopo de Funcionalidade; e
    1. Reutilização.

1) Organização

Os módulos ajudam a organizar o código do aplicativo em partes coesas, tornando-o mais compreensível e fácil de manter.

2) Escopo de Funcionalidade

Os módulos definem escopos de funcionalidade. Isso significa que os componentes, diretivas e serviços declarados em um módulo estão disponíveis apenas para outros componentes do mesmo módulo, a menos que sejam exportados.

3) Reutilização

Os módulos podem ser reutilizados em diferentes partes do aplicativo. Isso promove a reutilização de código.

Módulo raiz (root module) no Angular

Todo aplicativo Angular possui um módulo raiz (root module) que é inicializado quando o aplicativo é carregado. Esse módulo é conhecido como AppModule por convenção.

Em aplicativos Angular maiores, é comum dividir as funcionalidades em módulos separados. Por exemplo, você pode ter um módulo para autenticação, outro para administração e assim por diante. Os módulos secundários normalmente são importados no módulo raiz ou em outros módulos secundários, conforme necessário.

Os módulos desempenham um papel crucial na estruturação e organização de aplicativos Angular. Eles permitem que você crie aplicativos escaláveis, mantendo a modularidade e a reutilização de código, o que é essencial para projetos de desenvolvimento de software bem-sucedidos.

Para aprender sobre modularização, você pode conferir o curso Angular: boas práticas de desenvolvimento com Modularização, Lazy Loading e Interceptors.

Standalone components

Os standalone components são agora o padrão no Angular, dispensando o uso de NgModule para agrupar componentes. Isso simplifica a estrutura e facilita a manutenção, já que os componentes podem ser usados de forma independente. As dependências, como CommonModule e RouterLink, são importadas diretamente dentro do componente, simplificando o processo.

Exemplo de componente standalone antes da versão 19:

import { CommonModule } from '@angular/common';
import { Component } from '@angular/core';

@Component({
  selector: 'app-hello',
  imports: [CommonModule],
  standalone: true,
  templateUrl: './hello.component.html',
  styleUrl: './hello.component.css'
})
export class HelloComponent {}

Como parte da atualização do Angular v19, um schematic executado pelo comando ng update remove automaticamente a propriedade standalone de componentes, diretivas e pipes autônomos, e define como false para componentes não standalone.

import { CommonModule } from '@angular/common';
import { Component } from '@angular/core';

@Component({
  selector: 'app-hello',
  imports: [CommonModule],
  templateUrl: './hello.component.html',
  styleUrl: './hello.component.css'
})
export class HelloComponent {}

Além disso, foi introduzido o sinalizador strictStandalone, que pode ser ativado para gerar um erro caso um componente, diretiva ou pipe não seja standalone. Isso permite reforçar o uso de APIs modernas em seu projeto, mas sua ativação não é obrigatória. Para habilitá-lo, adicione a seguinte configuração no tsconfig.json:

{
  "angularCompilerOptions": {
    "strictStandalone": true
  }
}

Lazy loading

Uma forma de otimizar a sua aplicação é usando o carregamento de módulos sob demanda, também conhecido como lazy loading.

O Lazy Loading é uma técnica fundamental no Angular para melhorar o desempenho e a eficiência das aplicações.

Essa abordagem permite carregar módulos sob demanda, em vez de carregar todos os módulos de uma vez. Assim, apenas os módulos necessários são carregados quando se navega para uma determinada parte do projeto, reduzindo o tempo de carregamento inicial.

Rotas

O sistema de roteamento do Angular permite criar aplicativos de página única (SPA) que podem navegar entre diferentes visualizações ou componentes sem a necessidade de recarregar a página.

Isso proporciona uma experiência de navegação mais suave, pois apenas partes específicas da página são atualizadas conforme a navegação ocorre. As rotas são gerenciadas por um módulo de roteamento, permitindo a definição de URLs amigáveis, parâmetros dinâmicos e até mesmo roteamento aninhado.

RxJS

O Reactive Extensions para JavaScript - RxJS é uma biblioteca que oferece suporte a programação reativa no Angular.

Ele permite trabalhar com fluxos de dados assíncronos de forma mais fácil e poderosa. No contexto do Angular, o RxJS é amplamente usado para:

  • Tratar eventos;
  • Fazer solicitações HTTP;
  • Gerenciar estado; e
  • Criar aplicativos mais responsivos e eficientes.

Veja o Curso sobre RxJS.

Signals

A API de signals oferece uma maneira mais simples e intuitiva de gerenciar estados na aplicação. Essa abordagem melhora a reatividade ao substituir observables do RxJS por uma alternativa mais direta e previsível. Com signals, o gerenciamento de estado torna-se mais claro e com menos riscos de erros relacionados à complexidade de observables e efeitos colaterais. Para entender melhor o uso dos signals, confira nosso artigo detalhado sobre o tema Entendendo os Signals do Angular.

Animações

O Angular oferece suporte nativo para animações, permitindo a criação de:

  • Transições suaves; e
  • Interações visuais em elementos da interface.

Isso é alcançado por meio de uma poderosa API que permite definir transições de estado e animações de forma declarativa. As animações podem ser aplicadas a eventos específicos, como a exibição ou ocultação de elementos, por exemplo.

Isso melhora significativamente a experiência de uso e possibilita a criação de aplicações mais atraentes, modernas e dinâmicas.

Acesse os cursos abaixo e aprenda a incluir animações e dar vida aos seus projetos Angular:

Acessibilidade

A acessibilidade desempenha um papel relevante no desenvolvimento web e o Angular incorpora práticas voltadas para essa área.

Os recursos integrados do Angular são essenciais para criar aplicativos acessíveis, tornando-os compatíveis com leitores de tela e em conformidade com as diretrizes de acessibilidade.

Isso inclui:

  • Suporte a rótulos;
  • Descrições para elementos visuais;
  • Capacidades de foco e navegação via teclado;
  • Adição de atributos ARIA (Accessible Rich Internet Applications) para melhorar a experiência de pessoas usuárias com deficiência visual ou mobilidade reduzida.

Caso queira aprender a tornar aplicações acessíveis com Angular, recomendamos o curso Acessibilidade no Angular: aprimorando formulários, modais e rotas.

Angular material

O Angular Material é uma biblioteca de componentes UI que segue os princípios do Material Design, criada pelo Google.

Ela oferece uma ampla variedade de componentes pré-construídos, como botões, caixas de diálogo, tabelas e muito mais, que podem ser facilmente integrados em aplicativos Angular.

O uso do Angular Material é vantajoso pelos seguintes motivos:

  • Economiza tempo de desenvolvimento;
  • Mantém a consistência visual; e
  • Fornece componentes acessíveis por padrão.

Isso torna mais fácil criar aplicativos que sejam inclusivos e atendam a um público mais amplo.

Aprenda sobre componentização com angular material:

Testes

O Angular oferece uma sólida estrutura de testes integrada, tornando a detecção de problemas e a manutenção de código uma tarefa mais acessível. Isso abrange tanto testes unitários, que examinam o comportamento de partes individuais do aplicativo, quanto testes de integração, que asseguram a harmonia entre as diferentes partes do sistema.

A utilização de ferramentas como Jasmine e Karma agiliza o processo de teste, tornando-o eficiente e eficaz.

Esses testes desempenham um papel fundamental na garantia de que o aplicativo continue a operar conforme o esperado mesmo após atualizações, o que contribui para aprimorar a qualidade e a confiabilidade do software.

Aprenda a implementar testes no angular com a Formação testes.

Recentemente, o Karma foi depreciado. Haviam alguns pontos de atenção em relação ao Karma por que ao usar navegadores reais na execução, os testes unitários acabavam sendo mais lentos, pesados e difíceis de integrar a sistemas CI (Continuous Integration).

Por isso, a versão 16 do Angular trouxe suporte experimental ao Jest, que é um executor de testes unitários baseado na execução direta no Node, sem a utilização de um navegador real. Assim, a equipe Angular ainda está trabalhando para tornar o Jest tão bem integrado ao framework quanto o Karma.

Já para os testes unitários já existentes baseados em navegadores, a equipe do Angular recomenda o uso do Web Test Runner e pretende adicionar suporte nas versões futuras do framework, inclusive, integrando o Web Test Runner ao Jasmine para tornar a experiência o mais similar possível à da atual composta por Jasmine e Karma.

Build

O processo de construção (build) no Angular representa a etapa em que o código-fonte é transformado em uma forma otimizada, pronta para implantação. O Angular CLI simplifica a criação e configuração desses builds, convertendo o código TypeScript em JavaScript e automatizando tarefas essenciais de construção.

Isso inclui a:

  • Minificação do código;
  • Otimização de imagens; e
  • Criação de pacotes (bundles) para reduzir o tamanho do aplicativo.

Tudo isso resultando em um melhor desempenho e eficiência durante a execução em produção. Além disso, o Angular oferece suporte ao conceito de lazy loading, reduzindo o tamanho inicial do carregamento e melhorando a experiência de uso.

Lançamentos regulares e versões LTS

A versão 19 foi lançada em Novembro de 2024 e caso você esteja se perguntando: “outra versão, como assim?”, vale ressaltar que o Angular adota um ciclo de lançamentos regulares, com novas versões sendo disponibilizadas a cada seis meses.

Acompanhar os lançamentos é importante porque o Angular garante suporte de longo prazo (LTS) para versões selecionadas, permitindo que empresas e pessoas desenvolvedoras planejem suas atualizações de maneira estruturada; e versões mais antigas não têm esse suporte. Manter suas aplicações atualizadas não só garante acesso às novas funcionalidades e melhorias de performance, como também aumenta a segurança e a compatibilidade do seu projeto.

Com a chegada da versão 19 do Angular, muitas melhorias e atualizações foram introduzidas para melhorar o desempenho do framework e a experiência de desenvolvimento de quem o utiliza.

Então, que tal conferir as principais mudanças desta versão e aprender como realizar o upgrade do seu projeto de forma segura?

Principais mudanças da versão 19

A versão 19 do Angular trouxe várias melhorias significativas. Vamos explorar os destaques:

Hidratação incremental (incremental hydration)

A hidratação incremental permite que partes específicas do template sejam carregadas e hidratadas sob demanda de acordo com triggers (eventos) específicos, melhorando o desempenho de aplicações renderizadas no servidor. Utilizando a sintaxe @defer, é possível definir quais componentes devem ser hidratados sob demanda.

Exemplo de uso:

// app.config.ts

import { provideClientHydration, withIncrementalHydration } from '@angular/platform-browser';

// Configuração no bootstrap do cliente
export const appConfig: ApplicationConfig = {
  providers: [
    provideClientHydration(withIncrementalHydration())
  ]
};

No template, utilize o @defer para marcar componentes para hidratação incremental:

@defer( hydrate on hover ) {
  <app-products-list />
} @placeholder {
  <div>Large component placeholder</div>
}

Configuração de rotas no servidor (server route configuration)

Agora é possível definir como as rotas serão renderizadas, oferecendo maior flexibilidade na renderização de páginas. Uma rota agora pode ser renderizada ao lado do cliente, ao lado do servidor ou até mesmo durante o build.

Você pode criar uma configuração de rotas no servidor declarando um array de objetos do tipo ServerRoute. Essa configuração geralmente é armazenada em um arquivo chamado app.routes.server.ts.

Exemplo de configuração de rotas:

// app.routes.server.ts
import { RenderMode, ServerRoute } from '@angular/ssr';

export const serverRoutes: ServerRoute[] = [
  {
    path: '', // Renderiza a rota "/" no cliente (CSR)
    renderMode: RenderMode.Client,
  },
  {
    path: 'sobre', // Esta página é estática, então usamos pré-renderização (SSG)
    renderMode: RenderMode.Prerender,
  },
  {
    path: 'perfil', // Esta página requer dados específicos do usuário, então usamos SSR
    renderMode: RenderMode.Server,
  },
  {
    path: '**', // Todas as outras rotas serão renderizadas no servidor (SSR)
    renderMode: RenderMode.Server,
  },
];

Para adicionar essa configuração à sua aplicação, use a função provideServerRoutesConfig.

Exemplo de configuração de aplicação:

// app.config.server.ts

import { provideServerRendering } from '@angular/platform-server';
import { provideServerRoutesConfig } from '@angular/ssr'
import { serverRoutes } from './app.routes.server';

const serverConfig: ApplicationConfig = {
  providers: [
    provideServerRendering(),
    provideServerRoutesConfig(serverRoutes),
    // ... outros providers ...
  ]
};

Renderização do lado do servidor sem Zone.js

A partir da versão 18, o Angular introduziu suporte experimental ao funcionamento sem a dependência do zone.js, um componente anteriormente essencial para a renderização no servidor. Ele notificava a pilha de serviços sempre que o framework concluía a renderização e a página estava pronta para ser enviada ao cliente.

Na versão 19, essa abordagem evoluiu com a identificação de que as principais causas de atraso na renderização são requisições pendentes e navegações em andamento. Para otimizar esse processo, o Angular passou a incorporar funcionalidades específicas no HttpClient e no Router, permitindo atrasar o envio da página até que a aplicação esteja completamente carregada.

Notificação de renderização com RxJS

Para maior controle sobre o fluxo de renderização, o Angular introduziu um operador do RxJS, que notifica a pilha de serviços de que ainda existem operações em andamento antes de considerar a aplicação estável. Veja um exemplo de uso:

import { pendingUntilEvent } from '@angular/ssr';
import { catchError, EMPTY } from 'rxjs';

subscription
  .asObservable()
  .pipe(
    pendingUntilEvent(injector), // Notifica que ainda há processos em andamento
    catchError(() => EMPTY),    // Trata erros para evitar interrupções
  )
  .subscribe();

Agora, quando a assinatura emite um novo valor, o Angular considera que a aplicação está estável; daí a pilha de serviços envia o HTML renderizado para o cliente.

Essa abordagem permite que o Angular ofereça uma experiência de renderização mais eficiente no servidor sem depender do zone.js, ao mesmo tempo em que mantém a capacidade de sincronizar a renderização com o estado da aplicação.

Novas funcionalidades: linkedSignal e resource

O Angular 19 também trouxe duas novas funcionalidades experimentais para atender a casos de uso comuns em aplicações: linkedSignal e resource. Essas novidades têm o objetivo de simplificar a integração com estados dependentes e operações assíncronas, proporcionando mais flexibilidade e clareza na manipulação de dados.

O que significa experimental?

Funcionalidades marcadas como experimentais no Angular, como linkedSignal e resource, estão em uma fase inicial de testes. Essas APIs podem não se tornar estáveis ou passar por alterações significativas antes de serem oficialmente lançadas.

Além disso, as políticas e práticas usuais do Angular não se aplicam a APIs experimentais. Isso significa que elas podem mudar a qualquer momento, até mesmo em atualizações de patch, sem seguir as regras normais de versionamento semântico. É importante que as equipes avaliem se os benefícios de usar essas APIs superam os riscos de possíveis quebras de compatibilidade.

1 - linkedSignal: sinal vinculado a outro estado

O linkedSignal facilita o gerenciamento de estados dependentes, como quando um estado precisa ser mutável, mas também acompanhar mudanças em um estado de nível superior.

Por exemplo, imagine um componente que gerencia opções e uma seleção atual. A seleção é reiniciada sempre que a lista de opções muda.

import { signal, linkedSignal } from '@angular/core';

const options = signal(['apple', 'banana', 'fig']);

// Seleção padrão é o primeiro item, mas pode ser alterada.
const choice = linkedSignal(() => options()[0]);
console.log(choice()); // apple

choice.set('fig');
console.log(choice()); // fig

// Quando as opções mudam, a seleção volta ao valor padrão.
options.set(['peach', 'kiwi']);
console.log(choice()); // peach

O linkedSignal expressa diretamente a relação entre options e choice, sem necessidade de effects.

2 - resource: integração com operações assíncronas

Com o resource, o Angular dá os primeiros passos para integrar signals com dados assíncronos, algo essencial para operações como chamadas de API.

Um resource tem três partes principais:

  • Função de requisição: define a requisição em termos de signals.
  • Carregador: executa a operação assíncrona com base na requisição.
  • Instância do resource: expõe signals para o valor (quando disponível) e o status (carregando, resolvido, com erro, etc).

Exemplo prático: carregar dados de um usuário com base em um ID vindo da rota.

import { Component } from '@angular/core';
import { resource, input, inject } from '@angular/core';
import { UserService } from './user.service';

@Component({
  selector: 'app-user-profile',
  template: `
    @if (user.value() as user) {
      <div>
        <h1>{{ user.name }}</h1>
      </div>
    }
  `
})
export class UserProfile {
  userId = input<number>();

  userService = inject(UserService);

  user = resource({
    request: this.userId,
    loader: async ({ request: id }) => await this.userService.getUser(id),
  });
}

O resource user rastreia automaticamente o estado da requisição (carregando, resolvido, com erro) e atualiza conforme necessário. Como muitas aplicações utilizam RxJS, a biblioteca inclui o rxResource para criar recursos a partir de observables.

Essas novas APIs oferecem maneiras mais claras de gerenciar estados dependentes e dados assíncronos no Angular, melhorando a produtividade e a legibilidade do código.

Atualização instantânea com Hot Module Replacement (HMR)

O Hot Module Replacement (HMR) recebeu melhorias significativas no Angular v19. Essa funcionalidade permite que alterações no código sejam aplicadas instantaneamente no navegador, sem recarregar a página. Agora, o HMR está ativado por padrão para estilos e, experimentalmente, para templates.

Entre os benefícios, estão as alterações de CSS refletidas em tempo real. E com relação aos templates, as mudanças estruturais no HTML também podem ser aplicadas sem recarregar, mantendo o estado da aplicação.

Para experimentar o HMR para templates, use:

NG_HMR_TEMPLATES=1 ng serve

Para desabilitar esse recurso, especifique "hmr": false como uma opção no servidor de desenvolvimento ou, alternativamente, utilize:

ng serve --no-hmr

Além dessas novidades, a nova versão traz uma série de outras melhorias:

  • Os componentes standalone agora são padrão, e uma nova ferramenta automatiza a transição, facilitando a manutenção do código;
  • O recurso "strictStandalone" oferece controle mais rigoroso na adoção de APIs modernas;
  • No que diz respeito à reatividade, a API effects está evoluindo, com mudanças baseadas no feedback da comunidade;
  • O Angular Material e o CDK foram aprimorados, com a introdução de melhorias na API de theming, tornando mais fácil personalizar os componentes;
  • O Material 3 está estável, oferecendo mais opções de personalização por meio de uma API Sass alimentada por tokens de design.

Que tal testar essas novas funcionalidades? Acesse o blog do angular e a documentação e conheça mais detalhes sobre todas as atualizações da nova versão! E para fazer o update da sua aplicação, acesse o guia de update do angular e aproveite as novidades.

Comunidade e Recursos de Aprendizado

O Angular tem uma comunidade ativa com fóruns e grupos de discussão, além do oferecimento da documentação oficial.

Você também pode utilizar bons livros de tecnologia e acessar o Guia de carreira em Angular.

Estude com as Formações de Angular da Alura:

Aprenda mais sobre ANGULAR gratuitamente

Acesse gratuitamente as primeiras aulas das formações Angular: crie aplicações web ágeis e Formação: Explore o framework Angular, feitas pela Escola de Front-end da Alura e continue aprendendo sobre temas como:

Ah! E aqui vai um vídeo caso você queira aprender a aprender melhor para potencializar seus estudos! Como aprender melhor? Com Diogo Pires | #HipstersPonto

Apostilas — Você profissional em T

Com as Apostilas de tecnologia sobre Front-End, Programação, UX & Design e Ciências de Dados da Alura avance nos estudos e no desenvolvimento da sua carreira em T.

Você poderá se aprofundar nos seguintes tópicos:

  • Desenvolvimento Web com HTML, CSS e JavaScript;
  • UX e Usabilidade aplicados em Mobile e Web;
  • Java para Desenvolvimento Web;
  • Java e Orientação a Objetos;
  • Python e Orientação a Objetos;
  • C# e Orientação a Objetos;
  • SQL e modelagem com banco de dados.

Baixe elas completas em: Apostilas da Alura — Conteúdo livre para o seu aprendizado.

Conclusão

Em resumo, o Angular é uma estrutura robusta que oferece ferramentas e abordagens avançadas para a criação de aplicativos web de alta qualidade e alto desempenho. Desde a construção da interface de uso até a comunicação com o servidor e a garantia de acessibilidade, o Angular abrange uma ampla gama de aspectos essenciais no desenvolvimento moderno de aplicativos web.

Novas versões e recursos estão sempre sendo desenvolvidos para atender às necessidades em constante evolução das pessoas desenvolvedoras e do mercado.

Que tal embarcar nessa jornada de aprendizado e fazer parte dessa comunidade também?

Nayanne Batista
Nayanne Batista

Nayanne (Nay) é uma paraibana arretada que fez transição de carreira para a TI depois de concluir um doutorado na área da saúde e ser professora no ensino superior. Graduada em Análise e Desenvolvimento de Sistemas, já atuou como Dev Frontend em projetos e hoje é Instrutora na Alura. Acredita completamente no poder transformador da educação e da tecnologia na vida das pessoas. Ama livros e café! :)

Veja outros artigos sobre Front-end