防止ng-click重复执行

目的:

在angularjs1.*中通过装饰器进行服务的功能扩展。这里需要防止按钮短时间内重复点击,造成服务器负载过高。我们需要通过覆写ng-click指令来实现。

知识点:
1.依赖注入
2.装饰器设计模式
3.指令的执行顺序
4.阻止事件传播
5.防抖机制

讲解:
1.AngularJS中默认实现了依赖注入,通过$http的方式注入需要的服务。内部实现机制是通过将函数的function进行tostring,然后进行解析。相当于JAVA中的反射机制。

2.装饰器设计模式


image.png

需要相同接口,装饰之后,返回原来功能。

3.指令的执行顺序
覆写ng-click有两个阶段,可以在编译阶段,也可以在执行阶段。由于compile阶段只进行一次,而link阶段则会运行多次。为了性能考虑,必须定义在compile阶段。

4.阻止事件传播
由于防抖当中需要在一定时间内禁止组件的事件传播功能,因此需要用到JS的三种事件阻断机制。
stopPropagation : 阻止对象的当前监听事件传播
preventDefault:阻止对象发生的浏览器默认事件(比如a标签打开链接),但是监听事件依然传播(a的click事件依然传递)。
stopImmediatePropagation:组织对象的全部监听事件传播。

5.防抖思想

代码实现:

$provide.decorator('ngClickDirective',['$delegate','$timeout',function($delegate,$timeout){//需要在app.conf中注入$provide
    var origin = $delegate[0].compile;//保存原compile函数 $delegate作为指令的引用 必须在编译阶段修改 不能在link阶段修改
    var defer = 1000;
    $delegate[0].compile = function(element,attrs,transclude){ //装饰compile函数 增加功能
        var disabled = false;
        function onClick(event) {
            if (disabled) {
                event.preventDefault();//阻止默认事件
                event.stopImmediatePropagation();//阻止所有事件传播 
            }
            else {
                disabled = true;
                $timeout(function(){disabled = false;},defer,false);//false表示不进行脏检查
            }
        }
        element.on('click',onClick);
        return origin(element,attrs,transclude);//改动compile之后自动触发link操作
    }
    return $delegate;//必须返回引用,否则angular报错
}]);

效果:


image.png

每秒点击三次,只触发一次操作。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 135,662评论 19 139
  • Android 自定义View的各种姿势1 Activity的显示之ViewRootImpl详解 Activity...
    passiontim阅读 175,764评论 25 709
  • 以下文章为转载,对理解JavaScript中的事件处理机制很有帮助,浅显易懂,特分享于此。 什么是事件? 事件(E...
    jxyjxy阅读 8,167评论 1 10
  • 30岁,而立之年。有人说过,人到中年,敌人只剩自己。是啊,你如果像我一样觉得生活一地鸡毛,充斥着空虚的忙碌,带着迷...
    橙子姜阅读 1,508评论 2 4
  • 一. GCD的核心概念 什么是CGDGCD, 全称Grand Central Dispatch, 又称中枢调度器他...
    面糊阅读 3,973评论 0 51