Realizacja czatu w angular

0

Pytanie

Obecnie mam nadrzędny składnik o nazwie czat i dwa podrzędnych składnika o nazwie panel boczny(składający się z listy użytkowników) i informacje o rozmowie(składający się z rozmowy z każdym użytkownikiem).. funkcjonalność, którą chcę, polega na tym, że jeśli nacisnę na każdego użytkownika, znajdującą się na pasku bocznym, chcę, aby czat ten użytkownik objawił się po prawej stronie, jak w WhatsApp web.. poniżej znajduje się niewielki kod strukturyzacji moich komponentów

Składnik czatu(nadrzędny składnik)

<div class="container-fluid">
<div class="row">
    <div class="col-5">
        <app-sidebar></app-sidebar>
    </div>

    <div class="col-7">
        <app-conversation-detail></app-conversation-detail>
    </div>
</div>
angular chat typescript whatsapp
2021-11-24 06:31:06
1

Najlepsza odpowiedź

0

Możesz zarządzać stanem w samym nadrzędnym składniku i po prostu przesłać dane do swojego sidebar i conversation-detail przez @Input().

Na początek, można by zrobić coś takiego.

@Component({
  selector: 'my-app',
  template: `
  <div class="row">
    <div class="col-5">
        <app-sidebar [convoList]="convoList" (userSelected)="selectUser($event)"></app-sidebar>
    </div>
    <div class="col-7">
        <app-conversation-detail [conversation]="conversation">
        </app-conversation-detail>
    </div>
</div>`,
  styleUrls: ['./app.component.css'],
})
export class AppComponent {
  selectedUser = null;
  conversation = null;
  convoList = [];

  constructor(private conversationService: ConversationService) {}

  selectUser(user: string) {
    this.selectedUser = user;
    this.conversation = this.getConversationsOfUser(user);
  }

  getConversationsOfUser(user: string) {
    return this.conversationService.getConversationOfUser(user);
  }
}

Można również korzystać z bardziej reaktywne podejście, za pomocą obserwowane obiekty.

2021-11-24 07:44:56

W innych językach

Ta strona jest w innych językach

Русский
..................................................................................................................
Italiano
..................................................................................................................
Română
..................................................................................................................
한국어
..................................................................................................................
हिन्दी
..................................................................................................................
Français
..................................................................................................................
Türk
..................................................................................................................
Česk
..................................................................................................................
Português
..................................................................................................................
ไทย
..................................................................................................................
中文
..................................................................................................................
Español
..................................................................................................................
Slovenský
..................................................................................................................