关于Angularjs1.x dom ready

在ng的响应式应用开发过程中,有时间我们想知道什么时间ng-repeat什么时候结束,以便让页面的loading mask消失,或者计算页面的高度什么的。。。可能有很多人一直以来没有什么好的方式来处理,今天,我就把我的做法跟大家分享一下。

angular.module('domChangedModule',[])
.directive('domChanged',['$rootScope','$interval',function($rootScope,$interval){
    return {
        restrict : 'A',
        link : function(scope,ele,attrs){
            scope.dom = {
                cAt : new Date(),
                oAt : new Date(),
                state : 'steady'
            };
            ele.bind("DOMSubtreeModified", function() {
                scope.dom.cAt = new Date();
            });
            $interval(function(){
                if(angular.equals(scope.dom.cAt,scope.dom.oAt)){
                    if(angular.equals(scope.dom.state,'changing')){
                        $rootScope.$broadcast('DOM:STEADY');
                        scope.dom.state = 'steady';
                    }
                }else{
                    scope.dom.oAt = scope.dom.cAt;
                    scope.dom.state = 'changing';
                    $rootScope.$broadcast('DOM:CHANING');
                }
            },500);
        }
    };
}]);

通常只需要在body上应用这个指令就行了

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

sleeper01

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值