AngularJS中如何使用trigger报错$digest already in progress

前端之家收集整理的这篇文章主要介绍了AngularJS中如何使用trigger报错$digest already in progress前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。

今天在使用trigger事件碰到问题:

例如我有两个按钮,button1和button2,在button2绑定了ng-click事件,现在想点击button1从而触发button2的ng-click事件。

代码中我直接用

angular.element(button2).triggerHandler(‘click‘);

控制台报错:

Error: [$rootScope:inprog] $digest already in progress

这是为什么呢?代码中我没有apply啊!网上查阅后在stackoverflow上发现有一国外哥们也碰到这种问题,原来不管是trigger还是triggerHandler都会触发apply,可是$digest已经运行了,此时我们就要手动停止$digest。$timeout可以达到此目的,改写代码

$timeout(function({
angular.element(button2).triggerHandler(‘click‘);
})

如果你引入了jquery,还可以这么写:

$timeout(function({
$(button2).trigger(‘click‘);
})

猜你在找的Angularjs相关文章