Split for ng repeat item?

前端 未结 3 897
一生所求
一生所求 2021-02-20 04:18

Simple question- if I have this in my controller:

$scope.somedata = \'Item 1, Item 2\'; // set from something else

is there a way to split some

相关标签:
3条回答
  • 2021-02-20 05:11

    commented delimiter here

    angular.module('myFilters', []).
      filter('split', function() {
        return function(input, delimiter) {
          //var delimiter = delimiter || ',';
    
          return input.split(delimiter);
        } 
      });
    

    You could use the filter like so: also added track by $index to avoid crash due to duplicate values

    <div ng-repeat="item in somedata | split:',' track by $index">
    
    0 讨论(0)
  • 2021-02-20 05:20

    The string the right of the | is resolved to the name of a filter (usually they are string formatting filters, but the angular team has also provided the filter filter, which returns a filtered array (a bit misleading because the two share the same name). You could create your own split filter to accomplish what you want:

    angular.module('myFilters', []).
      filter('split', function() {
        return function(input, delimiter) {
          var delimiter = delimiter || ',';
    
          return input.split(delimiter);
        } 
      });
    

    You could use the filter like so:

    <div ng-repeat="item in somedata | split">
    

    Or specify a delimiter:

    <div ng-repeat="item in somedata | split:,">
    

    Consider the above pseudo-code because I haven't tested it.

    Le plunker: http://plnkr.co/edit/hk6F0Y6p5YAXv6fyXfSz?p=preview

    0 讨论(0)
  • 2021-02-20 05:21

    I guess I'm too late, but why not simply do this:

    <div ng-repeat="item in somedata.split(',')">{{item}}</div>
    

    works just fine.

    JSBin for evidence!

    0 讨论(0)
提交回复
热议问题