帖子:no dom manipulation from angular js controllers
关注点(来自帖子):不要使用控制器
操纵DOM – 控制器应仅包含业务逻辑.将任何表示逻辑放入控制器会显着影响其可测试性. Angular对大多数情况和指令进行数据绑定以封装手动DOM操作.
问题:如果我有一个简单的角度应用程序和按钮单击我调用我的控制器的功能.在该函数中,我想做一些简单的业务逻辑,并根据业务逻辑输出我想隐藏/显示一个按钮.
什么是最好的方法.
我目前的做法是:PLUNKER EXAMPLE
(这种做事的方式是否会破坏角度js领域的规律.是否反对测试?
请纠正我)
解决方法
当你发现自己处于想要使用jQuery直接在控制器中与dom对话的情况时,就应该查看指令了. http://docs.angularjs.org/guide/directive
我同意@tasseKATT,将重置按钮代码上的ng-click代码移动到一个函数中 – 即使只是为了理智.
编辑
这可以测试吗?是的 – 远比将内容放入HTML或直接依赖/修改DOM更重要.
在这种情况下,您需要测试的是您的范围函数执行它们应该做的事情 – 并且相信Angular人员已经测试了它们的绑定按照记录的方式工作的事实.您不必测试ng-click调用您的函数,您必须在使用您的函数所执行的任何参数调用时测试它,您的规范应该如此.
至于更容易在内联或在document.ready等中编写这种类型的代码 – 这只是习惯Angular处理方式的一部分.来自多年来与jQuery绑定,它肯定需要一些习惯.我认为以旧的方式做这件事更难.
查看本网站上关于测试Angular的帖子 – 有关于测试控制器,指令,服务等的文章 – 真的帮我把它们整合在一起. http://www.benlesh.com/2013/05/angularjs-unit-testing-controllers.html