AngularJS使用Filter自定义过滤器控制ng-repeat去除重复功能示例
程序员文章站
2022-03-31 14:10:50
本文实例讲述了angularjs使用filter自定义过滤器控制ng-repeat去除重复功能。分享给大家供大家参考,具体如下:
本文实例讲述了angularjs使用filter自定义过滤器控制ng-repeat去除重复功能。分享给大家供大家参考,具体如下:
<!doctype html> <html> <head> <meta charset="utf-8"> <title>www.jb51.net ng-repeat去除重复</title> <script src="http://apps.bdimg.com/libs/angular.js/1.4.6/angular.min.js"></script> </head> <body> <div ng-app="myapp" ng-controller="myctrl"> <p ng-repeat="x in items | unique:'id'"> {{x.id}}---{{x.name}} </p> </div> <script> //angularjs 自定义过滤器 //1.使用过滤器,去除重复 angular.module('common', []).filter('unique', function () { return function (collection, keyname) { console.info(collection); console.info(keyname); var output = [], keys = []; angular.foreach(collection, function (item) { var key = item[keyname]; if (keys.indexof(key) === -1) { keys.push(key); output.push(item); } }); return output; } }); var app = angular.module('myapp', ['common']); app.controller('myctrl', function ($scope) { //$scope.items = [1, 2, 3,2]; //当前unique 的过滤只针对,对象数组过滤 $scope.items = [ { id: 1, name: 'zhangsan' }, { id: 2, name: 'lisi' }, { id: 1, name: 'zhangsan' }, ]; }); </script> </body> </html>
运行结果:
ps:这里再为大家提供几款相关工具供大家参考使用:
在线去除重复项工具:
在线文本去重复工具:
更多关于angularjs相关内容感兴趣的读者可查看本站专题:《angularjs指令操作技巧总结》、《angularjs入门与进阶教程》及《angularjs mvc架构总结》
希望本文所述对大家angularjs程序设计有所帮助。