码迷,mamicode.com
首页 > 其他好文 > 详细

解决重复点击onClick事件,多次触发问题

时间:2016-06-23 00:54:07      阅读:1630      评论:0      收藏:0      [点我收藏+]

标签:

在配置文件中加入一下代码,即可解决全局的onClick重复点击。此方法是重写ngClick事件,可以保护多次点击

app.config([‘$provide‘, function ($provide) {
        $provide.decorator(‘ngClickDirective‘,[‘$delegate‘,‘$timeout‘, function ($delegate,$timeout) {
            var original = $delegate[0].compile;
                  var delay = 500;
            $delegate[0].compile = function (element, attrs, transclude) {

                var disabled = false;
                function onClick(evt) {
                    if (disabled) {
                        evt.preventDefault();
                        evt.stopImmediatePropagation();
                    } else {
                        disabled = true;
                        $timeout(function () { disabled = false; }, delay, false);
                    }
                }
                //   scope.$on(‘$destroy‘, function () { iElement.off(‘click‘, onClick); });
                element.on(‘click‘, onClick);

                return original(element, attrs, transclude);
            };
            return $delegate;
        }]);
    }]);

 

解决重复点击onClick事件,多次触发问题

标签:

原文地址:http://www.cnblogs.com/earl-yongchang/p/5609102.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!