最新消息:雨落星辰是一个专注网站SEO优化、网站SEO诊断、搜索引擎研究、网络营销推广、网站策划运营及站长类的自媒体原创博客

javascript - AngularJS: OrderBy Descending (null entries) - Stack Overflow

programmeradmin1浏览0评论

I'm using Angular JS and Google Places API to build an web app.

I have an ng-repeat which is currently being ordered by "rating" descending(orderBy:'-rating'). So it will list x places from the Google Places API JSON file in the descending order based on the rating.

HOWEVER, items/places that don't have a rating are classed as null and these entries are shown at the top of my ng-repeat feed. These should go to the bottom of the feed as they don't have a rating?

So an example of how i'd like this it to look is:

<ng-repeat orderBy:'-rating'>
  <place rating="5"/>
  <place rating="4.2"/>
  <place rating="2.8"/>
  <place rating="null"/>
  <place rating="null"/>
</ng-repeat>

What's the best way of going about this?

I'm using Angular JS and Google Places API to build an web app.

I have an ng-repeat which is currently being ordered by "rating" descending(orderBy:'-rating'). So it will list x places from the Google Places API JSON file in the descending order based on the rating.

HOWEVER, items/places that don't have a rating are classed as null and these entries are shown at the top of my ng-repeat feed. These should go to the bottom of the feed as they don't have a rating?

So an example of how i'd like this it to look is:

<ng-repeat orderBy:'-rating'>
  <place rating="5"/>
  <place rating="4.2"/>
  <place rating="2.8"/>
  <place rating="null"/>
  <place rating="null"/>
</ng-repeat>

What's the best way of going about this?

Share Improve this question asked Apr 22, 2016 at 13:36 Dayle SalmonDayle Salmon 2812 silver badges11 bronze badges 1
  • Check out this answer stackoverflow./questions/18604374/… – DrinkBird Commented Apr 22, 2016 at 13:39
Add a ment  | 

1 Answer 1

Reset to default 12

To sort with null or undefined value using orderBy filter. use [] notation orderBy:[ '!rating', '-rating', ].

That will show null or undefined value at the bottom.

like:

 <li ng-repeat="option in options | orderBy:[ '!rating', '-rating', ]">{{option.name}}</li>

If you want only null values to go to the bottom you can use:
orderBy: [ 'rating === null', '-rating' ]
For all falsy values except 0 you can do:
orderBy: [ 'rating !== 0 && !rating', '-rating' ]

发布评论

评论列表(0)

  1. 暂无评论