I'm using ng-repeat to bind image from a directive (same as we usually make stars rating). In my case I have images, some of them should have caption, not all. Is there a way to make a condition, which will show a caption for second and last images only? without creating an array for all images
My html:
<ul class="qty">
<li ng-repeat="image in imagesArray">
<img ng-model="imgUrl" ng-src="{{imgUrl}}">
<div>caption</div>
</li>
My app:
var myDirectives = (function () {
var myDirectives = angular.module('myDirectives', []);
myDirectives.directive('myImages', function () {
return {
restrict: 'A',
scope: {
qty: '='
},
link: function ($scope) {
$scope.imgUrl = "http://farm6.staticflickr.com/5579/14671096893_806ec359b7_m.jpg";
$scope.imagesArray = [];
for (var i = 0; i < $scope.qty; i++) {
$scope.imagesArray.push({});
}
},
templateUrl: function () { return 'stars.html' },
}
});
return myDirectives; }());
Yes, you can use $last and $first.
Consult the ngRepeat documentation for more information about it.
<ul class="qty">
<li ng-repeat="image in imagesArray">
<img ng-model="imgUrl" ng-src="{{imgUrl}}">
<div ng-if="$first || $last">caption</div>
</li>