angular
.module('app', []);
<!DOCTYPE html>
<html ng-app="app">
<head>
<meta charset="utf-8">
<title>AngularJS Plunker</title>
<script>document.write('<base href="' + document.location + '" />');</script>
<link rel="stylesheet" href="style.css" />
<script data-require="angular.js@1.5.x" src="https://code.angularjs.org/1.5.8/angular.min.js" data-semver="1.5.8"></script>
<script src="app.js"></script>
<script src="app.component.js"></script>
<script src="ordinal.filter.js"></script>
</head>
<body>
<app></app>
</body>
</html>
/* Put your css in here */
var app = {
template: `
<div>
<ul>
<li ng-repeat="num in $ctrl.numbers">
{{ num }}
</li>
</ul>
</div>
`,
controller($filter) {
var numbers = [
1,2,3,4,5,6,7,8,9,10,
11,12,13,14,15,16,17,18,19,20
];
this.numbers = numbers.map(function (number) {
return $filter('ordinal')(number);
})
}
};
angular
.module('app')
.component('app', app);
function ordinal() {
return function(value) {
var suffix = '';
var last = value % 10;
var specialLast = value % 100;
if (!value || value < 1) {
return value;
}
if (last === 1 && specialLast !== 11) {
suffix = 'st';
} else if (last === 2 && specialLast !== 12) {
suffix = 'nd';
} else if (last === 3 && specialLast !== 13) {
suffix = 'rd';
} else {
suffix = 'th';
}
return value + suffix;
};
}
angular
.module('app')
.filter('ordinal', ordinal);