A todo list example which loops over object by ng-repeat
:
var app = angular.module('toDolistApp', []);_x000D_
app.controller('toDoListCntrl', function() {_x000D_
var self = this;_x000D_
self.toDoListItems = {};// []; //dont use square brackets if keys are string rather than numbers._x000D_
self.doListCounter = 0;_x000D_
_x000D_
self.addToDoList = function() { _x000D_
var newToDoItem = {};_x000D_
newToDoItem.title = self.toDoEntry;_x000D_
newToDoItem.completed = false; _x000D_
_x000D_
var keyIs = "key_" + self.doListCounter++; _x000D_
_x000D_
self.toDoListItems[keyIs] = newToDoItem; _x000D_
self.toDoEntry = ""; //after adding the item make the input box blank._x000D_
};_x000D_
});_x000D_
_x000D_
app.filter('propsCounter', function() {_x000D_
return function(input) {_x000D_
return Object.keys(input).length;_x000D_
}_x000D_
});
_x000D_
<script src="https://ajax.googleapis.com/ajax/libs/angularjs/1.2.23/angular.min.js"></script>_x000D_
<body ng-app="toDolistApp"> _x000D_
<div ng-controller="toDoListCntrl as toDoListCntrlAs">_x000D_
Total Items: {{toDoListCntrlAs.toDoListItems | propsCounter}}<br />_x000D_
Enter todo Item: <input type="text" ng-model="toDoListCntrlAs.toDoEntry"/>_x000D_
<span>{{toDoListCntrlAs.toDoEntry}}</span>_x000D_
<button ng-click="toDoListCntrlAs.addToDoList()">Add Item</button> <br/>_x000D_
<div ng-repeat="(key, prop) in toDoListCntrlAs.toDoListItems"> _x000D_
<span>{{$index+1}} : {{key}} : Title = {{ prop.title}} : Status = {{ prop.completed}} </span>_x000D_
</div> _x000D_
</div> _x000D_
</body>
_x000D_