angularjs中判断ng-repeat是否迭代完
来源:互联网 发布:安卓微信加好友软件 编辑:程序博客网 时间:2024/06/15 10:27
angular中的ng-repeat指令会自动迭代数组然后你就可以将这些迭代的数据在页面逐条显示。但是怎样才知道数据迭代完了,其实还是有方法的,今天就介绍一种方法来判断ng-repeat是否已经迭代完。众所周知ng-repeat会为每一个repeat的对象创建一个控制器,我们就利用这个来判断。
首先我们要定义一个数组
$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指令,并为他们创建控制器。
<body ng-controller="app1Controller"><content> <!--为每一个repeat的对象创建一个itemRepeatCtrl控制器--> <div class="item" ng-controller="itemReaptCtrl" ng-repeat="li in testArrray track by li.id"> {{li.value}} </div></content></body>
接着就是为他们创建子控制器
.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 } })}])
然后在父控制器中接受广播
$scope.$on('ngRepeatFinished', function (data) { //接收广播,一旦repeat结束就会执行 console.log("恭喜你,repeat结束了!");});
看控制器中有打印,证明此方法有效
有时候需要在ng-repeat 指令repeat结束之后进行一些操作时便可以使用这种方法。
0 0
- angularjs中判断ng-repeat是否迭代完
- angularJs中ng-repeat实例
- AngularJS中使用ng-repeat的index
- ng-repeat 在angularJS中用法
- AngularJS中ng-repeat对象的问题
- AngularJS中ng-repeat使用心得
- angularjs ng-repeat
- angularjs ng-repeat
- Angularjs中的ng-repeat
- angularJS ng-repeat
- angularjs ng-repeat
- angularjs-ng-repeat
- angularjs ng-repeat
- AngularJS中ng-app、ng-model、ng-bind、ng-init、ng-repeat、自定义指令
- angularjs使用ng-repeat不用包含在html元素中
- angularjs中使用ng-repeat需要注意的东西
- 解决AngularJS中ng-repeat不更新视图的问题
- AngularJS中 ng-repeat 排序后的 $index变化
- 【操作系统】 进程与线程
- MVC 数据验证
- 常量指针与指针常量
- 10位世界级投资大师100金句
- iOS AVQueuePlayer 详解
- angularjs中判断ng-repeat是否迭代完
- Android开发中AccessibilityService的使用
- 玩转Google开源C++单元测试框架Google Test系列(gtest)之一 - 初识gtest
- 2015百度笔试题(软件)
- Linux命令行发送邮件
- STL 算法使用
- 启动型service
- python生成二维码
- 样式规则多次编写