- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
我正在尝试使用 ng2-bootrap 在我的 angular2 应用程序中实现分页。我正在关注 http://valor-software.github.io/ng2-bootstrap/#pagination
我的app.html
<div>
<div class="col-lg-12 text-right">
<pagination [totalItems]="totalItems" [itemsPerPage]='2' (pageChanged)="pageChanged($event)" [(ngModel)]="currentPage" [maxSize]="maxSize"
class="pagination-sm" [boundaryLinks]="true"></pagination>
</div>
</div>
我的组件
import { Component, View, Inject} from 'angular2/core';
import { CORE_DIRECTIVES } from 'angular2/common';
import { PAGINATION_COMPONENTS } from 'ng2-bootstrap/ng2-bootstrap';
// webpack html imports
@View({
templateUrl: '/scripts/src/components/demo/demo.html',
directives: [PAGINATION_COMPONENTS, CORE_DIRECTIVES]
})
@Component({
selector: 'tabs-demo',
})
export class DemoComponent {
private totalItems: number = 64;
private currentPage: number = 4;
private maxSize: number = 5;
private bigTotalItems: number = 175;
private bigCurrentPage: number = 1;
private setPage(pageNo: number): void {
this.currentPage = pageNo;
};
private pageChanged(event: any): void {
console.log('Page changed to: ' + event.page);
console.log('Number items per page: ' + event.itemsPerPage);
};
}
在不点击分页的情况下多次触发pageChange事件
最佳答案
实际上每次更新组件的 page
属性时都会触发该事件(这可以通过编程方式完成,无需与 UI 进行任何交互)。
其实这个事件在初始化pagination
组件时触发了3次,原因如下:
来自 ngInit
方法。这是组件生命周期的一部分。
export class Pagination implements ControlValueAccessor, OnInit, IPaginationConfig, IAttribute {
(...)
ngOnInit() {
(...)
this.page = this.cd.value;
(...)
}
(...)
}
来自 writeValue
方法。调用此方法是因为该组件是 ngModel 兼容的。当 ngModel
中关联的表达式更新时,将使用新值调用此方法。在初始化期间,writeValue
方法被调用两次:第一次使用 null
值,然后使用 1
值。
export class Pagination implements ControlValueAccessor, OnInit, IPaginationConfig, IAttribute {
(...)
writeValue(value:number) {
this.page = value;
this.pages = this.getPages(this.page, this.totalPages);
}
(...)
}
也就是说,在这个初始化阶段之后,pageChanged
只会在每次 page
更新时触发一次。
编辑
在查看了 ng2-bootstrap 的代码后,如果不更新分页组件的代码,我不知道该怎么做。
以下是您可以在此类中进行的更新(文件 node_modules/ng2-bootstrap/components/pagination/pagination.ts
):
更新 set page
block 以仅在 inited
属性为 true
时触发事件:
public set page(value) {
this._page = (value > this.totalPages) ? this.totalPages : (value || 1);
if (this.inited) { // <---------------
this.pageChanged.next({
page: this._page,
itemsPerPage: this.itemsPerPage
});
}
}
更新 ngOnInit
方法,不要在其末尾将 inited
属性设置为 true:
ngOnInit() {
(...)
//this.inited = true;
}
在第一次调用 writeValue
结束时将 inited
属性设置为 true:
writeValue(value:number) {
this.page = value;
this.pages = this.getPages(this.page, this.totalPages);
if (!this.inited) {
this.inited = true;
}
}
这样,pageChanged
事件只会在分页初始化阶段被调用一次。
希望对你有帮助,蒂埃里
关于pagination - ng2-bootstrap pagination pageChanged 触发多次,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/35081261/
有人可以告诉我 Bootstrap、Twitter Bootstrap 和 Bootstrap 3 之间有什么区别吗? 最佳答案 在 CSS 框架的上下文中,Bootstrap 和 Twitter B
什么是 Bootstrap 文档中的屏幕阅读器??? >>> bootstrap document 不知道什么是屏幕阅读器? 最佳答案 它是视力不佳或由于某种原因无法从屏幕上阅读的人使用的工具;它会向
我想更新网站上的 Bootstrap,但我不知道安装的版本。 如何仅使用 bootstrap.css 和 bootstrap.min.js 文件来识别 bootstrap 版本? CSS 文件中没有版
很抱歉问了这么一个愚蠢的问题,但我真的不清楚这些。 Bootstrap 是一个非常棒的库,它节省了开发人员的大量工作。 因为它提供了很多功能,比如 节省大量时间。 响应式功能。 一致的设计。 便于使用
我正在使用 ng2-bootstrap对于 Angular 2 项目。 这个包同时支持Bootstrap 3和4,我安装后默认使用Bootstrap 3。我没有找到任何关于切换的信息。 如何从 Boo
我计划在我的项目中使用 Bootstrap 4 和 angular 4,但我对 npm install --save @ng-bootstrap/ng-bootstrap 和 npm install
单击删除按钮后,我设置了警报。 但它的默认高度更大,我想让它更小(高度)。 我试过 display-4 属性(property),但它没有工作。 我已通过 w-50 将宽度设置为屏幕的一半,但警报的一
我使用 Bootstrap 按钮下拉菜单来显示表单。我通过调用 stopPropagation 禁用了单击时消失的下拉菜单(当用户操作表单时) .表单的元素之一是下拉列表。如果我使用 native h
twitter-bootstrap 中的“bootstrap”一词是什么意思?在许多 gem 中都有“bootstrap”这个词。我搜索了其中的含义,但无法得出结论。那么有人可以在这种情况下给出“Bo
由于 Bootstrap 5 不再使用 jQuery 并且正在使用 vanilla JS,我想知道是否仍然建议使用 Bootstrap-Vue,不管 Bootstrap-Vue 还不支持 Bootst
我正在使用 codeigniter 框架,我正在使用 bootstrap typeahead,一切都很好,但我的问题是当我将它放在 bootstrap 模式中时,bootstrap typeahead
我刚刚完成安装 bootstrap 5 版本 ^5.0.0-alpha1并在 app.js 中导入 Bootstrap import "bootstrap" 其他.js var myModal = n
我一直在尝试在使用选项卡的页面上实现 ScrollSpy。 这是我的 body 标签: 这是我的标签 HTML: Home Profile
如果您选择使用 Bootstrap-Xtra,您是否应该也包括原始的 bootstrap.css,或者 bootstrap-xtra.css 应该是一个完整的替代品。 例如,bootstrap-xtr
我正在使用 bootbox 创建一个对话框。 bootbox.dialog({ message: 'Datepicker input: ', title: "Custom label"
我正在将使用 Bootstrap 构建的 Web 应用程序迁移到 React 和 react-bootstrap,两者都很棒。我在 react-bootstrap 中没有看到的一件事是如何顺利集成 B
我正在使用 Bootstrap 3 RC,默认按钮是带有黑色文本的深灰色,而不是带有黑色文本的浅灰色。我已经尝试过 CDN 链接和离线。我还清空了我的浏览器缓存以防万一。有没有其他人经历过这个?这可能
在我的一个项目中,我曾经有 bootstrap-tagsinput http://timschlechter.github.io/bootstrap-tagsinput沿着 bootstrap-2.3
下拉菜单在 Angular-UI-Bootstrap 中不起作用?使用 Bootstrap-3 CSS 以下是代码。链接Click me for a dropdown出现。但不会在点击时切换。怎么了?
如何在 Bootstrap Table 中添加 Bootstrap 按钮 最佳答案 我已经想出了解决办法。我想和大家分享。 这是我的 table : # Visit
我是一名优秀的程序员,十分优秀!