本文實例講述了AngularJS監聽ng-repeat渲染完成的兩種方法。分享給大家供大家參考,具體如下:
監聽ng-repeat渲染完成有兩種方法
一、最實用的方法:
<ul class="pprt_content"> <li ng-repeat="src in imageHotList track by $index" ng-click='goGoodsDet(src.goodsId,src.merchId)' on-finish-render-filters="completeRepeat"> <img ng-src="{{productUrl}}{{src.imageName}}"> </li></ul>
對應作用域controller:
$scope.completeRepeate= function(){alert('1')}
自定義指令directive:
var app = angular.moduler('myApp',[]);app.directive('onFinishRenderFilters', ['$timeout', function ($timeout) { return { restrict: 'A', link: function(scope,element,attr) { if (scope.$last === true) { var finishFunc=scope.$parent[attr.onFinishRenderFilters]; if(finishFunc) { finishFunc(); } } } };}])
二、使用廣播事件
/** Controller文件中的代碼* Setup general page controller*/MetronicApp.controller('simpleManageController', ['$rootScope','$scope', 'settings','$http', function($rootScope, $scope, settings,$http) { $scope.$on('ngRepeatFinished', function (ngRepeatFinishedEvent) { //下面是在table render完成后執行的js FormEditable.init(); Metronic.stopPageLoading(); $(".simpleTab").show(); });});MetronicApp.directive('onFinishRenderFilters', function ($timeout) { return { restrict: 'A', link: function(scope,element,attr) { if (scope.$last === true) { $timeout(function() { scope.$emit('ngRepeatFinished'); }); } } };});
HTML
<!--HTML頁面的代碼,添加標簽onFinishRenderFilters(格式有變):on-finish-render-filters--> <tr style="display: none" class="simpleTab" ng-repeat="simpleProduct in simpleProducts" on-finish-render-filters> <td> {{simpleProduct.productNo}} </td></tr>
更多關于AngularJS相關內容感興趣的讀者可查看本站專題:《AngularJS指令操作技巧總結》、《AngularJS入門與進階教程》及《AngularJS MVC架構總結》
希望本文所述對大家AngularJS程序設計有所幫助。
新聞熱點
疑難解答