AngularJS中如何使用trigger报错$digest already in progress
2016-07-27 15:06
477 查看
今天在使用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入门教程之控制器详解
- AngularJS 开发中常犯的10个错误
- AngularJS入门教程之Scope(作用域)
- AngularJS入门之动画
- AngularJS——依赖注入
- AngularJs渲染完毕后执行指定操作
- AngularJS 模型详细介绍及实例代码
- angular2 之 form表单
- 详解Angular开发中的登陆与身份验证
- AngularJS 指令详细介绍
- angular.js分页代码的实例
- angular.bind
- AngularJS缓存
- AngularJS指令替换内容
- AngularJS鼠标进入划出事件
- 浅谈依赖注入
- angularjs表单数据提交-对象方式提交
- AngularJS 路由
- AngularJS 依赖注入
- AngularJS 动画