angularjs中判断ng-repeat是否迭代完的实例

angular中的ng-repeat指令会自动迭代数组然后你就可以将这些迭代的数据在页面逐条显示。但是怎样才知道数据迭代完了,其实还是有方法的,今天就介绍一种方法来判断ng-repeat是否已经迭代完。众所周知ng-repeat会为每一个repeat的对象创建一个控制器,我们就利用这个来判断。

首先我们要定义一个数组

rush:js;"> $scope.testArrray = [ {id: 1,value: 1},{id: 2,value: 2},{id: 3,value: 3},{id: 4,value: 4},{id: 5,value: 5},{id: 6,value: 6},{id: 7,value: 7},{id: 8,value: 8}];

然后我们repeat这个数组在html页面中使用ng-repeat指令,并为他们创建控制器。

rush:js;">

<div class="item" ng-controller="itemReaptCtrl" ng-repeat="li in testArrray track by li.id">
{{li.value}}

接着就是为他们创建子控制器

rush:js;"> .controller('itemReaptCtrl',['$scope',function ($scope) { $scope.$watch($scope.$last,function () { console.log("执行了一次!"); if($scope.$last){ //$scope.$last是来判断是否是最后一个ng-repeat对象, 如果是则$scope.$last的值为true,反之则为false $scope.$emit('ngRepeatFinished'); // 由于是向父控制器中发布广播,所有用$emit } }) }])

然后在父控制器中接受广播

rush:js;"> $scope.$on('ngRepeatFinished',function (data) { //接收广播,一旦repeat结束就会执行 console.log("恭喜你,repeat结束了!"); });

看控制器中有打印,证明此方法有效

有时候需要在ng-repeat 指令repeat结束之后进行一些操作时便可以使用这种方法

以上这篇angularjs中判断ng-repeat是否迭代完的实例就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持编程之家。

相关文章

前言 做过web项目开发的人对layer弹层组件肯定不陌生,作为l...
前言 前端表单校验是过滤无效数据、假数据、有毒数据的第一步...
前言 图片上传是web项目常见的需求,我基于之前的博客的代码...
前言 导出Excel文件这个功能,通常都是在后端实现返回前端一...
前言 众所周知,js是单线程的,从上往下,从左往右依次执行,...
前言 项目开发中,我们可能会碰到这样的需求:select标签,禁...