单元测试 – AngularJS 2.0 – 如何测试应用程序?
发布时间:2020-12-17 18:04:19 所属栏目:安全 来源:网络整理
导读:我正在构建一个尽可能多的AngularJS 2.0的AngularJS应用程序(使用ES6),因此我不会有很多迁移工作. 如你所知,我们在 = v1.4中知道它们不会有控制器 我的一个指令的示例代码 class LoginSidebar { constructor() { } someMethod(){ } }LoginSidebar.$inject =
我正在构建一个尽可能多的AngularJS 2.0的AngularJS应用程序(使用ES6),因此我不会有很多迁移工作.
如你所知,我们在< = v1.4中知道它们不会有控制器 我的一个指令的示例代码 class LoginSidebar { constructor() { } someMethod(){ } } LoginSidebar.$inject = []; export default function() { return { scope: {},templateUrl: 'tpl/path/to/loginSidebar.tpl.html',replace: true,controller: LoginSidebar,controllerAs: 'loginSidebarCtrl' }; }; 这就是我的app.js的样子 import loginSidebar from "./js/component/loginSidebar/LoginSidebar.js"; angular.module('myModule',[ 'ngNewRouter','ngAnimate' ]) .directive("loginSidebar",loginSidebar); 你可以看到我没有.controller(),所以我该如何测试类中的方法? PS. 解决方法
您可以使用全局名称定义控制器,然后在指令中引用它:
//LoginSidebarController.js class LoginSidebarController { // controller code here } export default LoginSidebarController //LoginSidebarDirective.js export default function() { return { scope: {},controller: 'LoginSidebarController',controllerAs: 'loginSidebarCtrl' }; }; //app.js import loginSidebarDirective from "./js/component/loginSidebar/LoginSidebarDirective.js"; import LoginSidebarController from "./js/component/loginSidebar/LoginSidebarController.js"; angular.module('myModule',[]) .directive('loginSidebar',loginSidebarDirective) .controller('LoginSidebarController',LoginSidebarController) 然后你可以要求控制器作为其他通常的控制器来独立于指令进行测试. 作为第二种方式,您可以通过angular.element().controller(‘loginSidebar’)方法访问控制器.像这样的东西: var testElm = angular.element('<login-sidebar />'); $compile(testElm); testElm.controller('loginSidebar') (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |
推荐文章
站长推荐
- angularjs – 在q库中等效于完成函数的angular j
- 在Scala类定义的开头,=>是什么意思?
- BootStrap selectpicker后台动态绑定数据的方法
- shell脚本-简单的添加用户并统计总用户数
- Shell特殊变量:Shell $0, $#, $*, $@, $?, $$和
- codis错误:ResponseError: handle request, slot
- angularjs – 根据角度.js排序显示和隐藏箭头图标
- bash Cookbook, 2nd Edition Solutions and Exam
- angular – “ObservableMedia”类型中的属性“s
- 【数据结构】二叉树2
热点阅读