Реализация чата в angular

0

Вопрос

В настоящее время у меня есть родительский компонент под названием чат и два дочерних компонента с именем боковая панель(состоящий из списка пользователей) и сведения о разговоре(состоящий из чата с каждым пользователем).. функциональность, которую я хочу, заключается в том, что если я нажму на любого пользователя, присутствующего на боковой панели, я хочу, чтобы чат этого пользователя открылся справа, как в WhatsApp web.. ниже приведен небольшой код структурирования моих компонентов

Компонент чата(родительский компонент)

<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

Лучший ответ

0

Вы можете управлять состоянием в самом родительском компоненте и просто передавать данные в свой sidebar и conversation-detail через @Input().

Для начала, вы могли бы сделать что-то вроде этого.

@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);
  }
}

Вы также можете использовать более реактивный подход, используя наблюдаемые объекты.

2021-11-24 07:44:56

На других языках

Эта страница на других языках

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