【问题标题】:AngularJS - placeholder for empty result from filterAngularJS - 过滤器空结果的占位符
【发布时间】:2013-01-14 22:43:52
【问题描述】:

我想要一个占位符,例如<No result> 当过滤结果返回空时。有人可以帮忙吗?我什至不知道从哪里开始......

HTML

<div ng-controller="Ctrl">
<h1>My Foo</h1>
<ul>
    <li ng-repeat="foo in foos">
        <a href="#" ng-click="setBarFilter(foo.name)">{{foo.name}}</a>
    </li>
</ul>
<br />
<h1>My Bar</h1>
<ul>
    <li ng-repeat="bar in bars | filter:barFilter">{{bar.name}}</li>
</ul>

</div>

JS

function Ctrl($scope) {

  $scope.foos = [{
    name: 'Foo 1'
  },{
    name: 'Foo 2'
  },{
    name: 'Foo 3'
  }];

  $scope.bars = [{
    name: 'Bar 1',
    foo: 'Foo 1'
  },{
    name: 'Bar 2',
    foo: 'Foo 2'
  }];

  $scope.setBarFilter = function(foo_name) {
    $scope.barFilter = {};
    $scope.barFilter.foo = foo_name;
  }
}

jsFiddlehttp://jsfiddle.net/adrn/PEumV/1/

谢谢!

【问题讨论】:

标签: javascript html angularjs


【解决方案1】:

这里是使用 ng-show 的技巧

HTML:

<div ng-controller="Ctrl">
<h1>My Foo</h1>
<ul>
    <li ng-repeat="foo in foos">
        <a href="#" ng-click="setBarFilter(foo.name)">{{foo.name}}</a>
    </li>
</ul>
<br />
<h1>My Bar</h1>
<ul>
    <li ng-repeat="bar in bars | filter:barFilter">{{bar.name}}</li>
</ul>
<p ng-show="(bars | filter:barFilter).length == 0">Nothing here!</p>

</div>

jsFiddle: http://jsfiddle.net/adrn/PEumV/2/

【讨论】:

  • 但是这种情况下过滤器执行了两次,有没有办法避免呢?
  • 感谢您的解决方案。我一直在使用github.com/a8m/angular-filter 此处提供的 groupBy 过滤器,但不幸的是,上面接受的答案不起作用。此方法可能会执行两次过滤器,但无论如何都解决了问题。
  • 在我的情况下,它可以在没有“== 0”的情况下工作。

    这里什么都没有!

【解决方案2】:

对只需要您指定一次过滤器的方法的调整:

  <li ng-repeat="bar in filteredBars = (bars | filter:barFilter)">{{bar.name}}</li>
</ul>
<p ng-hide="filteredBars.length">Nothing here!</p>

Fiddle

【讨论】:

  • 这是更好的解决方案,因为您只需要声明一次过滤器。 +1
  • 问题是“这里什么都没有!”部分显示和隐藏非常快。当您通过 ajax 请求获取数据时,在显示返回的数据之前会有一段延迟,此时您可以看到“这里没有任何内容!”部分出现和消失。
  • @Temega - 你可以在 div 中添加一个“ng-hide”类
  • @Temega 你可以使用 ng-show="filteredBars.length === 0"
  • 我使用 ng-controller="FooController as $ctrl" 并做了 "bar in $ctrl.filteredBars = (bars | filter:barFilter)" 所以我什至可以在外面使用 $ctrl.filteredBars.length ng重复。感谢这个史诗般的提示!
【解决方案3】:

取自this官方文档,他们是这样做的:

ng-repeat="friend in friends | filter:q as results"

然后将结果作为数组使用

<li class="animate-repeat" ng-if="results.length == 0">
  <strong>No results found...</strong>
</li>

完整的sn-p:

<div ng-controller="repeatController">
I have {{friends.length}} friends. They are:
<input type="search" ng-model="q" placeholder="filter friends..." aria-label="filter friends" />


<ul class="example-animate-container">
    <li class="animate-repeat" ng-repeat="friend in friends | filter:q as results">
      [{{$index + 1}}] {{friend.name}} who is {{friend.age}} years old.
    </li>
    <li class="animate-repeat" ng-if="results.length == 0">
      <strong>No results found...</strong>
    </li>
  </ul>
</div>

【讨论】:

  • 我怀疑自从第一次提出这个问题以来情况发生了变化,但鉴于目前这正是 Angular 的文档建议您解决问题的方式,我会说这是目前的正确方法。
  • 我找不到另一个例子。这是“隐藏”的,在他们的动画文档中,我偶然在我需要它的同一天注意到它,或者我认为我不会记得。
猜你喜欢
  • 1970-01-01
  • 1970-01-01
  • 2021-12-11
  • 1970-01-01
  • 1970-01-01
  • 2016-01-28
  • 1970-01-01
  • 2014-01-03
  • 2013-02-21
相关资源
最近更新 更多