《AngularJS》--监听angularjs列表数据是否渲染完毕
来源:互联网 发布:免费erp软件 编辑:程序博客网 时间:2024/06/04 21:52
小编在项目中遇到这样一个需求,利用AngularJS在手机页面双向绑定一些数据,而且这些数据是以列表的形式展现出来的,当这些数据渲染完成之后,需要在列表上面加载一些图片,而且这些图片是不断的自动切换。想来想去,于是就用到了自己定义的指令,下面是具体的代码。
1、HTML代码
<div class="bd"> <ul> <li ng-repeat="item in list " on-finish-render-filters> <a class="pic" ng-href="{{item.redirectUrl}}"><img src="{{item.imgUrl}}"/></a> <a class="tit" ng-href="{{item.redirectUrl}}"> <span class="db fl one_text_overflow w100p" style="padding-right: 61px; box-sizing: border-box;"> {{item.name}} </span> </a> </li> </ul> </div>
2、定义方法,请求后台数据
var app=angular.module("MyModule",[]); app.controller('controller1', function ($scope, $http, $log, $state, $timeout, $stateParams) { $scope.list = []; $http.get(url) .success(function (data) { if (data != null) { $scope.list=data; } }) .error(function (ex, state) { console.log(state + ":" + ex); }); });
3、监听最后一条数据是否渲染完毕
app.directive('onFinishRenderFilters', function ($timeout) { return { restrict: 'A', link: function (scope, element, attr) { if (scope.$last === true) { //判断是否是最后一条数据 $timeout(function () { scope.$emit('ngRepeatFinished'); //向父级scope传送ngRepeatFinished命令 }); } } }; });
4、最后一条数据渲染完毕后,父级Scope接收到事件,并作出图片切换的操作。
$scope.$on('ngRepeatFinished', function (ngRepeatFinishedEvent) { //下面是在table render完成后执行的js TouchSlide({ slideCell: "#slideBox", titCell: ".hd ul", //开启自动分页 autoPage:true ,此时设置 titCell 为导航元素包裹层 mainCell: ".bd ul", effect: "leftLoop", autoPage: true,//自动分页 autoPlay: true //自动播放 }); }); });
这样,页面列表的最后一条数据加载完毕后,图片就加载出来了。需求实现了。现在看看我们用到的代码,$emit是用来向父级Scope传送事件,$brodercast是向子级scope传送事件,而$scope.$on()是监听事件,利用这几个函数就能完成类似的功能。
1 0
- 《AngularJS》--监听angularjs列表数据是否渲染完毕
- angularjs列表数据是否渲染完毕
- 如何监听Angularjs列表数据是否渲染完毕,配合jQuery操作DOM,指令的规范
- AngularJs渲染完毕后执行指定操作
- angularJs监听ng-repeat渲染完成
- AngularJs--ng-repeate渲染完毕后执行的代码
- AngularJS判断页面是否已经渲染结束
- angularjs-渲染完数据后执行js
- angularjs数据重复,查询数据是否存在
- AngularJS渲染性能分析
- didMoveToSuperview可以监听父类数据是否加载完毕
- AngularJs锚点监听
- angularJS添加事件监听
- AngularJS 监听变量变化
- AngularJS 04(监听、指令)
- AngularJs数据渲染到视图后再执行操作
- AngularJS实战之渲染完数据后执行js
- angularjs请求数据解析并渲染到表格中(天气预报)
- Java实现斐波那契数列并输出前10000个数值
- XML Schema的基本语法
- 如何在最短的时间内理解Java中的动态代理?
- java-面试0613
- LNK1123: 转换到 COFF 期间失败: 文件无效或损坏
- 《AngularJS》--监听angularjs列表数据是否渲染完毕
- 欢迎使用CSDN-markdown编辑器
- #95 – x:Name vs. Name
- mybatis接口的xml常用配置
- java与C#学习笔记一初始化
- 第16周项目-小玩文件
- Java单元测试(Junit+Mock+代码覆盖率)
- ubuntu14.04 kylin使用android studio时,adb 报错
- bootstrap-datepicker 与bootstrapValidator同时使用时,选择日期后,无法正常触发校验