angular指令监听ng-repeat渲染完成后执行自定义事件方法

今天工做中遇到须要用到ng-repeat遍历渲染完后执行某个操做,angular自己并无提供监听ng-repeat渲染完成的指令,因此须要本身建立自定义指令。javascript

在ng-repeat模板实例内部会暴露出一些特殊属性$index/$first/$middle/$last/$odd/$even,$index会随着每次遍历(从0开始)递增,当遍历到最后一个时,$last的值为true,因此能够经过判断$last的值来监听ng-repeat的执行状态,java

怎么在遍历过程当中拿到$last的值:自定义指令app

var app = angular.module('app',[]);

app.directive('repeatFinish',function(){
    return {
        link: function(scope,element,attr){
            console.log(scope.$index)
            if(scope.$last == true){
                scope.$eval( attr.repeatFinish );
            }
        }
    }
})

app.controller('appCtrl',function($scope,$element){
    $scope.arr = [1,2,3,4,5,6];
    $scope.tip = '';

    //定义repeat完成后要执行的方法,方法名可自行定义
    $scope.repeatDone = function(){
        $scope.tip = 'ng-repeat完成,我要开始搞事情了!!!';
     //执行本身要执行的事件方法
    }
});

调用时使用angular调用指令的方法就能够了。code

<div ng-repeat="i in arr" repeat-finish="repeatDone();">
    <p ng-bind="i"></p>
</div>
相关文章
相关标签/搜索