AngularJS监听ng-repeat渲染完成的两种方法


Posted in Javascript onJanuary 16, 2018

本文实例讲述了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程序设计有所帮助。

Javascript 相关文章推荐
jquery选择器的选择使用及性能介绍
Jan 16 Javascript
jQuery aminate方法定位到页面具体位置
Dec 26 Javascript
javascript中SetInterval与setTimeout的定时器用法
Aug 24 Javascript
jQuery+CSS实现滑动的标签分栏切换效果
Dec 17 Javascript
jQuery Mobile动态刷新页面样式的实现方法
May 28 Javascript
jQuery实现鼠标滑过图片移动特效
Dec 08 Javascript
Vue 中使用vue2-highcharts实现top功能的示例
Mar 05 Javascript
Vue props用法详解(小结)
Jul 03 Javascript
微信小程序动态添加view组件的实例代码
May 23 Javascript
axios实现简单文件上传功能
Sep 25 Javascript
在vue中根据光标的显示与消失实现下拉列表
Sep 29 Javascript
webpack介绍使用配置教程详解webpack介绍和使用
Jun 25 Javascript
微信小程序实现流程进度的图样式功能
Jan 16 #Javascript
使用vue官方提供的模板vue-cli搭建一个helloWorld案例分析
Jan 16 #Javascript
vue单页面打包文件大?首次加载慢?nginx带你飞,从7.5M到1.3M蜕变过程(推荐)
Jan 16 #Javascript
详解layui中的树形关于取值传值问题
Jan 16 #Javascript
基于JavaScript实现抽奖系统
Jan 16 #Javascript
详解JavaScript基础知识(JSON、Function对象、原型、引用类型)
Jan 16 #Javascript
浅谈vue的props,data,computed变化对组件更新的影响
Jan 16 #Javascript
You might like
新手配置 PHP 调试环境(IIS+PHP+MYSQL)
2007/01/10 PHP
PHP异步调用socket实现代码
2012/01/12 PHP
php文件打包 下载之使用PHP自带的ZipArchive压缩文件并下载打包好的文件
2012/06/13 PHP
php实现图片上传并利用ImageMagick生成缩略图
2016/03/14 PHP
非常好的js代码
2006/06/27 Javascript
基于jquery实现的定时显示与隐藏div广告的实现代码
2013/08/22 Javascript
Jquery通过JSON字符串创建JSON对象
2014/08/24 Javascript
jQuery插件pagination实现分页特效
2015/04/12 Javascript
jquery动态增加删减表格行特效
2015/11/20 Javascript
jQuery下拉菜单的实现代码
2016/11/03 Javascript
Bootstrap CSS布局之按钮
2016/12/17 Javascript
JS和canvas实现俄罗斯方块
2017/03/14 Javascript
轻量级JS Cookie插件js-cookie的使用方法
2018/03/22 Javascript
vue 解决文本框被键盘遮住的问题
2019/11/06 Javascript
微信小程序自定义顶部组件customHeader的示例代码
2020/06/03 Javascript
vue select 获取value和lable操作
2020/08/28 Javascript
node中短信api实现验证码登录的示例代码
2021/01/20 Javascript
Python Property属性的2种用法
2015/06/21 Python
Python实现身份证号码解析
2015/09/01 Python
Python 2与Python 3版本和编码的对比
2017/02/14 Python
详解Python 切片语法
2019/06/10 Python
Django项目基础配置和基本使用过程解析
2019/11/25 Python
Python 识别12306图片验证码物品的实现示例
2020/01/20 Python
Python使用进程Process模块管理资源
2020/03/05 Python
python模块内置属性概念及实例
2021/02/18 Python
Roxy美国官网:澳大利亚冲浪、滑雪健身品牌
2016/07/30 全球购物
GLAMGLOW格莱魅美国官网:美国知名的面膜品牌
2016/12/31 全球购物
迪奥官网:Dior.com
2018/12/04 全球购物
学校文明单位申报材料
2014/05/06 职场文书
卖房协议书样本
2014/10/30 职场文书
2015年幼儿园大班工作总结
2015/04/25 职场文书
承诺书模板大全
2015/05/04 职场文书
2016十一国庆节感言
2015/12/09 职场文书
2019感恩宣传标语!
2019/07/05 职场文书
详解CSS开发过程中的20个快速提升技巧
2021/05/21 HTML / CSS
以MySQL5.7为例了解一下执行计划
2022/04/13 MySQL