加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 综合聚焦 > 服务器 > 安全 > 正文

《AngularJS》--监听angularjs列表数据是否渲染完毕

发布时间:2020-12-17 10:33:32 所属栏目:安全 来源:网络整理
导读:小编在项目中遇到这样一个需求, 利用AngularJS在手机页面双向绑定一些数据,而且这些数据是以列表的形式展现出来的,当这些数据渲染完成之后,需要在列表上面加载一些图片,而且这些图片是不断的自动切换。 想来想去,于是就用到了自己定义的指令,下面是具

小编在项目中遇到这样一个需求,利用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()是监听事件,利用这几个函数就能完成类似的功能。

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读