Как инкапсулировать настроенный угловой компонент, содержащий события?

#angular #typescript #ng-bootstrap

Вопрос:

Я использую компонент разбиения на страницы из ng-bootstrap (который я настроил), и я хочу повторно использовать компонент в других местах, без необходимости переписывать код.

Поскольку ngb-pagination компонент имеет свойство двусторонней привязки page , мне нужно правильно предоставить это свойство родительскому компоненту.

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

 import { Component, Input, Output, OnInit, EventEmitter } from '@angular/core';

import { faChevronLeft, faChevronRight, faAngleDoubleLeft, faAngleDoubleRight } from '@fortawesome/free-solid-svg-icons';

@Component({
  selector: 'app-pagination',
  template: `
    <div class="d-flex justify-content-between p-2">
      <ngb-pagination [collectionSize]="collectionSize" [page]="page" (pageChange)="pageChange" [pageSize]="pageSize" [boundaryLinks]="true">
        <ng-template ngbPaginationFirst>
          <fa-icon class="fas" [icon]="faAngleDoubleLeft" aria-hidden="true"></fa-icon>
        </ng-template>

        <ng-template ngbPaginationLast>
          <fa-icon class="fas" [icon]="faAngleDoubleRight" aria-hidden="true"></fa-icon>
        </ng-template>

        <ng-template ngbPaginationPages let-page let-pages="pages">
          <li class="ngb-custom-pages-item" *ngIf="pages.length > 0">
              <div class="form-group d-flex flex-nowrap px-2">
                <label id="paginationInputLabel" for="paginationInput" class="col-form-label mr-2 ml-1">Page</label>

                <input #i type="text" inputmode="numeric" pattern="[0-9]*" class="form-control custom-pages-input"
                    id="paginationInput" [value]="page" (keyup.enter)="selectPage(i.value)" (blur)="selectPage(i.value)"
                    (input)="formatInput($any($event).target)" aria-labelledby="paginationInputLabel paginationDescription"
                    style="width: 2.5rem"/>

                <span id="paginationDescription" class="col-form-label text-nowrap px-2">of {{pages.length}}</span>
              </div>
          </li>
        </ng-template>

        <ng-template ngbPaginationPrevious>
          <fa-icon class="fas" [icon]="faChevronLeft" aria-hidden="true"></fa-icon>
        </ng-template>

        <ng-template ngbPaginationNext>
          <fa-icon class="fas" [icon]="faChevronRight" aria-hidden="true"></fa-icon>
        </ng-template>
      </ngb-pagination>
    </div>
  `,
  styleUrls: ['./pagination.component.scss']
})
export class PaginationComponent implements OnInit {
  faChevronLeft = faChevronLeft;
  faChevronRight = faChevronRight;
  faAngleDoubleLeft = faAngleDoubleLeft;
  faAngleDoubleRight = faAngleDoubleRight;

  @Input() collectionSize: number = 20;
  @Input() page: number = 1;
  @Output() pageChange = new EventEmitter<number>();
  @Input() pageSize: number = 10;

  constructor() { }

  ngOnInit(): void {
  }

  selectPage(page: string) {
    this.page = parseInt(page, 10) || 1;
  }

  formatInput(input: HTMLInputElement) {
    input.value = input.value.replace('/[^0-9]/g', '');
  }
}
 

И я просто использую компонент следующим образом (я следую полному примеру таблицы).:

 <app-pagination [collectionSize]="(total$ | async)!" [(page)]="service.page" [pageSize]="service.pageSize">
</app-pagination>
 

Итак, как я могу правильно отобразить свойства и события?

Ответ №1:

Вам нужно генерировать события из компонента:

 <ngb-pagination [collectionSize]="collectionSize" [page]="page" (pageChange)="pageChange.emit($event)" [pageSize]="pageSize" [boundaryLinks]="true">
 

   selectPage(page: string) {
    this.page = parseInt(page, 10) || 1;
    this.pageChange.emit(this.page);
  }
 

Комментарии:

1. Это сработало, спасибо! Я думал, что событие будет запущено из стороннего компонента.

2. Это отдельные источники событий, вы не можете перезаписать их в шаблоне (pageChange)="here you already have $event variable so it's code which passed to callback"