4

我按照http://bazalt-cms.com/ng-table/example/4的说明在 ng-table 中创建了一个过滤器框

我的代码与示例相同:在 html 中创建过滤器:

<table ng-table="tableParams" show-filter="true" class="table">
    <tr ng-repeat="user in $data">
        <td data-title="'Name'" filter="{ 'name': 'text' }">

现在我们可以看到布局:

在此处输入图像描述

但我不想要表格中的过滤器框,如下所示:

在此处输入图像描述

文件管理器在表格上方我的过滤器框代码:

<input type="text" ng-model="filter.name" />
<table ng-table="tableParams" show-filter="false" class="table">
    <tr ng-repeat="user in $data">
        <td data-title="'Name'" filter="{ 'name': 'text' }">
            {{user.name}}
        </td>

...使用 ng-model="filter.name" 进行绑定,但它不起作用...

有没有办法实现我的想象力?

4

3 回答 3

10

帕姆错了。你永远不应该在 ngtable 或任何已经完成它的组件之后过滤。否则,你会有意想不到的事情发生。

只需修改您的表参数并通过引用您的过滤器对象进行绑定:

$scope.filter = {name: 'T'};
$scope.tableParams = new ngTableParams({
    page: 1,            // show first page
    count: 10,          // count per page
    filter: $scope.filter
}, {
    total: data.length, // length of data
    getData: function($defer, params) {
        // use build-in angular filter
        var orderedData = params.filter() ?
               $filter('filter')(data, params.filter()) :
               data;

        $scope.users = orderedData.slice((params.page() - 1) * params.count(), params.page() * params.count());

        params.total(orderedData.length); // set total for recalc pagination
        $defer.resolve($scope.users);
    }
});

并删除您的 tr 中的过滤器内容

<input type="text" ng-model="filter.name"/>
<table ng-table="tableParams"  class="table">
    <tr ng-repeat="user in $data">
        <td data-title="'Name'" >
            {{user.name}}
        </td>
        <td data-title="'Age'">
            {{user.age}}
        </td>
    </tr>
</table>

通过这种方式,数据在数据重新加载时被过滤,而不是在数据显示时被过滤。并且您的 $scope.filter 绑定在 UI 上并由 ngTable 监视。

Plunker 上的演示

于 2014-10-20T14:48:54.640 回答
1

我试图按照@Clems 回答但无济于事。做了一些研究,我从ngTable Github 存储库中找到了一个解决方案,并且有一个更简单的解决方案。

<input type="text" ng-model="tableParams.filter()['name']" />
<table ng-table="tableParams" show-filter="false" class="table">
    <tr ng-repeat="user in $data">
        <td data-title="'Name'" filter="{ 'name': 'text' }">
            {{user.name}}
        </td>
     </tr>
</table>

虽然唯一的问题(我现在正试图找出)是如何通过单个输入过滤多个列。希望这可以帮助

于 2017-10-02T16:12:49.457 回答
-1

你可以这样做:

  1. 创建一个单独的文本框和一个单独的表格。文本框的ng-model 属性应该是您需要过滤数据的属性。因此,此文本框可以放置在页面中的任何位置。

    <input type="text" ng-model="name" />
    
  2. 使用为文本框提供的值绘制表格ng-repeat并提供具有值的过滤器ng-model

    <tr ng-repeat="item in items|filter:name">
    

这是一个示例:

<table>
            <th>Item Name</th>
            <th>Item Price</th>
            <tr ng-repeat="item in items|filter:name">
                <td>{{item.name}}</td>
                <td>{{item.price}}</td>
            </tr>

</table>
<input type="text" ng-model="name" />
于 2014-08-22T06:57:05.893 回答