如何在Angular单元测试中从另一个控制器的rootScope将方法添加到rootScope中
How to add a method into rootScope from the rootScope from another controller in an Angular unit test?
我正在单元测试一个函数,该函数从另一个控制器调用$rootScope方法。有没有办法将该函数添加到我要测试的控制器的$rootScope中?我使用的测试环境包括Jasmine、Karma、PhantomJS等。
如果你想在测试中手动添加方法,你可以在测试运行前使用Jasmine的beforeEach()来设置mock/implement方法,所以通过使用inject()
,你可以传入$rootScope
并设置你的方法
由于$rootScope在所有控制器之间共享,您可以直接在$rootScope对象中定义函数,请考虑将函数定义在app.run处理程序中,否则,您必须确保已加载控制器才能定义函数,下面的示例显示了这两种方法:
<div ng-app="myApp">
<div ng-controller="Ctrl1">
<h1>Controller 1</h1>
<button ng-click="myFunc()">Test $rootScope.myFunc()</button>
<button ng-click="toBeDefniendinCtrl1()">Test $rootScope.toBeDefniendinCtrl1()</button>
</div>
<div ng-controller="Ctrl2">
<h1>Controller 2</h1>
<button ng-click="myFunc()">Test $rootScope.myFunc()</button>
<button ng-click="toBeDefniendinCtrl1()">Test $rootScope.toBeDefniendinCtrl1()</button>
</div>
</div>
<script>
var app = angular.module('myApp', []);
app.run(function($rootScope){
$rootScope.myFunc = function (){ alert("hi"); }
$rootScope.toBeDefniendinCtrl1 = null;
})
app.controller('Ctrl1', function($scope, $rootScope) {
$rootScope.toBeDefniendinCtrl1 = function (){ alert("hello from Ctrl1"); }
});
app.controller('Ctrl2', function($scope, $rootScope) {
});
</script>
请参阅以下位置的工作示例:http://jsbin.com/xiyozitage/edit?html,输出
相关文章:
- electronic BrowserWindow的最小高度和宽度在hide()show()方法之后不起作用
- 有没有任何方法可以将控制器从文件加载到ui路由器$stateProvider中
- 数组在递归方法中设置为null
- 打破承诺链的好方法是什么
- 在使用Polymer'加载所有json文件后执行方法;s的核心ajax
- 使用“;这个“;JavaScript原型方法中的关键字
- 序列化数据属性中对象的最可靠方法
- 使用Objective-C的JavaScript注入方法
- 有没有一种方法可以添加相同的项目val=“0”;4〃;到JavaScript中数组的每个对象
- 有没有一种方法可以防止img get请求使用css或js发生
- Javascript,有没有一种方法可以将数组写成没有逗号或空格的单个文本字符串
- toBoolean方法类似于toString
- 如何在单击复选框后调用控制器方法
- 是否有任何方法可以使用jQuery替换在数组中定义值的文本
- 如何在Angular单元测试中从另一个控制器的rootScope将方法添加到rootScope中
- AngularJs Jasmine 无法在方法$rootScope中调用$scope方法
- AngularJS$rootScope$发射而不发射该方法
- $rootScope和工厂方法
- 访问控制器中的$rootScope方法
- 如何使用$rootScope.Scope的使用方法