AskOverflow.Dev

AskOverflow.Dev Logo AskOverflow.Dev Logo

AskOverflow.Dev Navigation

  • Início
  • system&network
  • Ubuntu
  • Unix
  • DBA
  • Computer
  • Coding
  • LangChain

Mobile menu

Close
  • Início
  • system&network
    • Recentes
    • Highest score
    • tags
  • Ubuntu
    • Recentes
    • Highest score
    • tags
  • Unix
    • Recentes
    • tags
  • DBA
    • Recentes
    • tags
  • Computer
    • Recentes
    • tags
  • Coding
    • Recentes
    • tags
Início / coding / Perguntas / 79585002
Accepted
derstauner
derstauner
Asked: 2025-04-22 00:54:56 +0800 CST2025-04-22 00:54:56 +0800 CST 2025-04-22 00:54:56 +0800 CST

Filtrar observável sem disparar solicitação HTTP

  • 772

Eu preencho uma grade com a seguinte linha de código:

this.gridData$ = this.userService.getUsers();

e este é o HTML correspondente:

[kendoGridBinding]="(gridData$ | async)!"

Funciona como esperado.

Também tenho um botão de exclusão. Clicar nele exclui o usuário. Depois disso, quero remover o usuário da lista, mas sem fazer uma solicitação HTTP extra. Tentei shareReplay, mas a solicitação extra está lá:

this.gridData$ = this.gridData$.pipe(
              shareReplay({ bufferSize: 1, refCount: true }),
              map((users) => {
                return users.filter(
                  (user) => user.userId !== this.currentDataItem.userId
                );
              })
            );

Como filtrar os dados da grade para excluir o usuário excluído sem nenhuma solicitação HTTP adicional? Ou devo armazenar os usuários em uma variável local no init e modificar o array ao adicionar, editar ou excluir e convertê-lo em um observável?

angular
  • 3 3 respostas
  • 85 Views

3 respostas

  • Voted
  1. Best Answer
    Naren Murali
    2025-04-22T01:48:57+08:002025-04-22T01:48:57+08:00

    Basta adicionar uma deletedUserspropriedade que seja um BehaviorSubject, que armazena os usuários excluídos.

    Usamos combineLatestpara filtrar os dados, sem precisar buscá-los novamente pela API. As alterações no deletedUsersbehaviorSubject acionarão um recálculo.

      deletedUsers = new BehaviorSubject([]);
    
      this.gridData$ = combineLatest(
        this.userService.getUsers(),
        this.deletedUsers
      ).pipe(
        map((users: any, deletedUsers: any) => users.filter(
           (user) => !deletedUsers.includes(user.userId)
        ));
      );
    

    Ao excluir um usuário, envie o ID para deletedUsersbehaviorSubject.

    this.deletedUsers.next([
      ...(this.deletedUsers.value() || []),
      1, // <--- deleted ID
    ]);
    

    OBSERVAÇÃO: Geralmente, é uma boa ideia atualizar a lista após as operações CRUD, para que seus usuários finais não trabalhem com dados obsoletos.

    • 1
  2. Jdwill916
    2025-04-22T03:47:22+08:002025-04-22T03:47:22+08:00

    Com base na resposta de Naren Murali, talvez seja melhor dar ao serviço a propriedade total sobre os dados do usuário. No momento, parece que o serviço apenas obtém os dados, que depois pertencem ao componente. Alterar seu serviço para algo como o seguinte pode ajudar:

    export class UserService {
      private deletedUserIdsSubject = new BehaviorSubject<number[]>([]); // list of user IDs that have been deleted
    
      public users$: Observable<User[]> = // public users observable that your components can use
        combineLatest([this.getUsers(), this.deletedUserIdsSubject]).pipe(
          map(([users, deletedUserIds]) => users.filter(user => !deletedUserIds.includes(user.id))) // filter out deleted users
        );
    
      public deleteUser(userId: number) {
        this.deletedUserIdsSubject.next([userId, ...this.deletedUserIdsSubject.getValue()]);
      }
    
      private getUsers(): Observable<User[]> { // make this private so that only the service can decide when to get fresh data
        // ...
      }
    }
    

    Seu componente poderia então usar this.userService.user$e this.userService.deleteUser()interagir com os dados do usuário, permitindo que o serviço se responsabilize pelos usuários. Você também pode adicionar métodos adicionais ao serviço para oferecer suporte a recursos como adição, filtragem e paginação. Essa abordagem é boa porque mantém os detalhes de como/quando os usuários são recuperados do componente. Se você precisar alterar a lógica posteriormente, o componente não se importa se o serviço atualiza a partir do servidor, faz uma exclusão na memória ou encontra algum outro método. Esses detalhes são problema do serviço, não do componente.

    • 0
  3. Vugar Abdullayev
    2025-04-22T01:16:01+08:002025-04-22T01:16:01+08:00
    public readonly users = signal([]);
    
    public ngOnInit(): void { 
      this.fetchUsers();
    }
    
    private fetchUsers(): void {
      this.userService.getUsers().pipe(take(1)).subscribe((data) => {
        this.users.set(data);
    );
    }
    
    private onDeleteSuccess(userId: number): void {
     const filteredUsers = this.users()?.filter((user) => user.userId !== userId);
    
     this.users.set(filteredUsers);
    }
    

    e em HTML:

    [kendoGridBinding]="users()"
    
    • -1

relate perguntas

  • pipe de data não funciona para elementos com conjunto de propriedades FormControlName

  • Posso colocar o serviço do componente reutilizável no módulo principal em Angular de acordo com o cenário mencionado

  • A caixa de diálogo Mat não fecha depois que a vinculação de dados mat-dialog-close é verdadeira

  • Não é possível renderizar o componente personalizado em app.component.html

  • Reutilização de component.html em mais de 2 arquivos .ts

Sidebar

Stats

  • Perguntas 205573
  • respostas 270741
  • best respostas 135370
  • utilizador 68524
  • Highest score
  • respostas
  • Marko Smith

    Reformatar números, inserindo separadores em posições fixas

    • 6 respostas
  • Marko Smith

    Por que os conceitos do C++20 causam erros de restrição cíclica, enquanto o SFINAE antigo não?

    • 2 respostas
  • Marko Smith

    Problema com extensão desinstalada automaticamente do VScode (tema Material)

    • 2 respostas
  • Marko Smith

    Vue 3: Erro na criação "Identificador esperado, mas encontrado 'import'" [duplicado]

    • 1 respostas
  • Marko Smith

    Qual é o propósito de `enum class` com um tipo subjacente especificado, mas sem enumeradores?

    • 1 respostas
  • Marko Smith

    Como faço para corrigir um erro MODULE_NOT_FOUND para um módulo que não importei manualmente?

    • 6 respostas
  • Marko Smith

    `(expression, lvalue) = rvalue` é uma atribuição válida em C ou C++? Por que alguns compiladores aceitam/rejeitam isso?

    • 3 respostas
  • Marko Smith

    Um programa vazio que não faz nada em C++ precisa de um heap de 204 KB, mas não em C

    • 1 respostas
  • Marko Smith

    PowerBI atualmente quebrado com BigQuery: problema de driver Simba com atualização do Windows

    • 2 respostas
  • Marko Smith

    AdMob: MobileAds.initialize() - "java.lang.Integer não pode ser convertido em java.lang.String" para alguns dispositivos

    • 1 respostas
  • Martin Hope
    Fantastic Mr Fox Somente o tipo copiável não é aceito na implementação std::vector do MSVC 2025-04-23 06:40:49 +0800 CST
  • Martin Hope
    Howard Hinnant Encontre o próximo dia da semana usando o cronógrafo 2025-04-21 08:30:25 +0800 CST
  • Martin Hope
    Fedor O inicializador de membro do construtor pode incluir a inicialização de outro membro? 2025-04-15 01:01:44 +0800 CST
  • Martin Hope
    Petr Filipský Por que os conceitos do C++20 causam erros de restrição cíclica, enquanto o SFINAE antigo não? 2025-03-23 21:39:40 +0800 CST
  • Martin Hope
    Catskul O C++20 mudou para permitir a conversão de `type(&)[N]` de matriz de limites conhecidos para `type(&)[]` de matriz de limites desconhecidos? 2025-03-04 06:57:53 +0800 CST
  • Martin Hope
    Stefan Pochmann Como/por que {2,3,10} e {x,3,10} com x=2 são ordenados de forma diferente? 2025-01-13 23:24:07 +0800 CST
  • Martin Hope
    Chad Feller O ponto e vírgula agora é opcional em condicionais bash com [[ .. ]] na versão 5.2? 2024-10-21 05:50:33 +0800 CST
  • Martin Hope
    Wrench Por que um traço duplo (--) faz com que esta cláusula MariaDB seja avaliada como verdadeira? 2024-05-05 13:37:20 +0800 CST
  • Martin Hope
    Waket Zheng Por que `dict(id=1, **{'id': 2})` às vezes gera `KeyError: 'id'` em vez de um TypeError? 2024-05-04 14:19:19 +0800 CST
  • Martin Hope
    user924 AdMob: MobileAds.initialize() - "java.lang.Integer não pode ser convertido em java.lang.String" para alguns dispositivos 2024-03-20 03:12:31 +0800 CST

Hot tag

python javascript c++ c# java typescript sql reactjs html

Explore

  • Início
  • Perguntas
    • Recentes
    • Highest score
  • tag
  • help

Footer

AskOverflow.Dev

About Us

  • About Us
  • Contact Us

Legal Stuff

  • Privacy Policy

Language

  • Pt
  • Server
  • Unix

© 2023 AskOverflow.DEV All Rights Reserve