Sla*_*ast 4 pagination angularjs angular-ui-grid
我正在尝试将一个小项目从jquery移植到angularjs.我使用DataTables绘制从我的虚拟机收到的诊断数据,这是一个例子:

DataTables可以很容易地对数据进行分页,这样做的好处是在导航时不会捕获鼠标滚动,这是当您的页面包含大量表格时的最佳解决方案.我现在正尝试使用angular-ui中的ui-grid做同样的事情,但是ng-grid中存在的分页选项不再存在(或者至少我无法找到它们).
有没有办法使用ui-grid进行客户端分页?有没有办法避免在不需要滚动表格时捕获鼠标滚动?如果不是,我只需要切换回ng-grid.
所以我无法详细解释每一步,但这是我开始工作的方式:
为您的模块添加分页依赖项
var app = angular.module('app', ['ui.grid', 'ui.grid.pagination']);
Run Code Online (Sandbox Code Playgroud)
在Controller Disable Scrollbars中并设置rowsPerPage:
$scope.gridOptions.enableScrollbars = false;
$scope.gridOptions.rowsPerPage = 15;
Run Code Online (Sandbox Code Playgroud)
不要忘记注册API(也在Controller中):
$scope.gridOptions.onRegisterApi = function (gridApi) {
$scope.gridApi = gridApi;
}
Run Code Online (Sandbox Code Playgroud)
将ui-grid-pagination-Directive添加到您的表中
<div ui-grid="gridOptions" ui-grid-pagination class="grid" external-scopes="$scope"></div>
Run Code Online (Sandbox Code Playgroud)
现在在HTML-Partial中添加按钮(我使用了Fontawesome和Bootstrap,但你不必这样做):
<button type="button" class="btn btn-default" ng-click="gridApi.pagination.previousPage()">
<span class="fa fa-angle-left"></span>
</button>
<span>Page: {{ gridApi.pagination.getPage() }}</span>
<span>/ {{ gridApi.pagination.getTotalPages() }}</span>
<button type="button" class="btn btn-default" ng-click="gridApi.pagination.nextPage()">
<span class="fa fa-angle-right"></span>
</button>
Run Code Online (Sandbox Code Playgroud)
而已!
嘿,刚刚在消息来源中找到了另一种方法:
gridApi.pagination.seek(page);
Run Code Online (Sandbox Code Playgroud)
还想提一下,我使用的是ui-grid v3.0.0-rc.12
| 归档时间: |
|
| 查看次数: |
6194 次 |
| 最近记录: |