首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >角度分页-分页组件

角度分页-分页组件
EN

Stack Overflow用户
提问于 2017-05-25 02:24:02
回答 1查看 766关注 0票数 0

我创建了一个分页组件,让用户浏览网格中的页面。我尝试在特定页面上使用此组件,但收到错误:

代码语言:javascript
复制
'pager' is not a known element:
1. If 'pager' is an Angular component, then verify that it is part of this module.
2. To allow any element add 'NO_ERRORS_SCHEMA' to the '@NgModule.schemas' of this component. ("
</div>

[ERROR ->]<pager  (get-page)="getPage($event)"></pager>

我做错了什么?我也将这个添加到了我的app.module中。

代码语言:javascript
复制
import { PagerComponent } from './shared/pager.component';

这是我的pager组件。

html:

代码语言:javascript
复制
<div>
    <button (click)="goToPage(1)" [disabled]="pageNumber==1">
        <md-icon>first_page</md-icon>
    </button>
    <button (click)="previous()" [disabled]="pageNumber==1">
        <md-icon>chevron_left</md-icon>
    </button>
    <input #input type="text" style="width: 30px;height:30px" (keyup.enter)="goToPage(input.value)" [(value)]="pageNumber" >

    <button (click)="next()" [disabled]="pageNumber==totalPages">
        <md-icon>chevron_right</md-icon>
    </button>
    <button (click)="goToPage(totalPages)" [disabled]="pageNumber==totalPages">
        <md-icon>last_page</md-icon>
    </button>
    <br />
    Showing page {{pageNumber}} of {{totalPages}} pages.
</div>

组件:

代码语言:javascript
复制
import {Component, Input, EventEmitter, OnInit} from '@angular/core';

@Component({
    selector: 'pager',
    templateUrl: 'pager.component.html',
    outputs: ['getPage: get-page']
})
export class PagerComponent {
    @Input('total-pages') totalPages: number;
    @Input('total-items') totalItems: number;

    getPage: EventEmitter<any> = new EventEmitter();
    totalPages: number;
    pageNumber: number;

    constructor(){
        this.pageNumber = 1;
    }

    goToPage(page:number){
        this.pageNumber = page;
        this.getPage.emit({
            pageNumber: page
        });
    }

    previous(){
        if(this.pageNumber <= 1 || this.pageNumber > this.totalPages || isNaN(this.pageNumber)) {
            return;
        }
        this.pageNumber = Number(this.pageNumber) - 1;
        this.goToPage(this.pageNumber);
    }

    next(){
        if(this.pageNumber >= this.totalPages || this.pageNumber < 1 || isNaN(this.pageNumber)){
            return;
        }

        this.pageNumber =  Number(this.pageNumber) + 1;
        this.goToPage(this.pageNumber);
    }
}

在另一个组件中的用法: html:

代码语言:javascript
复制
<pager  (get-page)="getPage($event)"></pager>

组件:

代码语言:javascript
复制
import { PagerComponent } from '../shared/pager.component';

@Component({
    templateUrl: './list.component.html',
    providers: [PagerComponent]
}) 
.....

    getPage(page) {
            this.getItems(page);
        }
EN

回答 1

Stack Overflow用户

发布于 2017-05-25 02:26:37

您导入了组件,但是否声明了它?

代码语言:javascript
复制
import { PagerComponent } from './shared/pager.component';

@NgModule({
  declarations: [PagerComponent] 
  // ...
})

此外,您不应该在另一个组件的providers数组中声明另一个组件。这是针对在该级别共享的注入服务的。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/44165984

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档