How to display placeholders in AngularJS for undefined expression values?

后端 未结 5 1690
情歌与酒
情歌与酒 2021-02-02 05:13

If I have an expression {{ x }} and x is undefined or null, then how can I display a placeholder for it?

I provided one solution

相关标签:
5条回答
  • 2021-02-02 05:42

    I would do it like this, but maybe there is a better way:

    angular.module('app').filter('placeholdEmpty', function(){
      return function(input){
        if(!(input == undefined || input == null)){
          return input;
        } else {
          return "placeholder";
        }
      }
    });
    

    and then use {{ x | placeholdEmpty}}

    0 讨论(0)
  • 2021-02-02 05:51

    {{ counter || '?'}}. Just pure javascript. || can be used as default value. Since it would be different empty messages in each, a generalized directive would not be suitable for many cases.

    If you want to apply a different class to empty ones, that's also built-in:

    <div ng-class="{empty: !counter}" ng-bind="counter || ?"></div>
    
    0 讨论(0)
  • 2021-02-02 05:56

    I do it with ng-show, like this:

    <strong>{{username}}</strong>
    <span class="empty" ng-show="!username">N/A</span>
    

    Sure, it adds a lot more elements to my view that I might be able to handle differently. I like though how easy it is to clearly see where my placeholder/empty values are, and I can style them differently as well.

    0 讨论(0)
  • 2021-02-02 05:58

    Implement default filter:

    app.filter('default', function(){
      return function(value, def) {
        return (value === undefined || value === null? def : value);
      };
    });
    

    And use it as:

    {{ x | default: '?' }}
    

    The advantage of the filter solution over {{ x || '?'}} is that you can distinguish between undefined, null or 0.

    0 讨论(0)
  • 2021-02-02 05:59

    Implementing default-ish filters works, but if you're using only numbers you can use angular's own number filter

    If the input is null or undefined, it will just be returned. If the input is infinite (Infinity or -Infinity), the Infinity symbol '∞' or '-∞' is returned, respectively. If the input is not a number an empty string is returned.

    {{ (val | number ) || "Number not provided"}}
    
    0 讨论(0)
提交回复
热议问题