编写“unit testable”;jQuery代码
Writing "unit testable" jQuery code?
到目前为止,我习惯在ready()函数中编写所有代码,如:
$(document).ready(function() {
// all my code
});
现在我看到,使用这种方法,我的代码不是"单元可测试的",例如我不能从QUnit访问ready()里面的东西。
什么是正确的方式来构建jQuery代码兼容使用ready()函数,并能够被测试?是否有一个好的开源代码库或项目来研究和学习?
让你的代码在ready处理程序中只调用ready处理程序之外的函数:
$(document).ready(function() {
// call some functions outside of handler
});
// most of my code
这样,你也可以调用这些函数进行单元测试。
注意,$(document).ready
有一个捷径:
$(function() {
// call some functions outside of handler
});
// most of my code
我看到两种方法。
-
将QUnit代码放入文档中,以便在您自己的代码之后运行。
-
把你的代码放到一个模块中
选项#2看起来像这样:
var MyModule = (function() {
// Your code
}());
$(document).ready(function() {
// Quit tests, referring to MyModule.xxx
});
在选项#2中,你不能访问模块中的私有元素。
Ben Cherry不久前在http://www.adequatelygood.com/2010/7/Writing-Testable-JavaScript上谈到了这个问题,他实际上对基于闭包的隐私做了一个有争议的评论,因为它对单元测试有影响。
最有效的方法之一是使用JS的"命名空间"来构建你的代码,实际上你可以从jQuery核心中得到一个很好的例子。
对于不可测试的jQuery脚本,我采用了这样一种奇怪的方法:
- 安装业力
- 包含所有不能在karma include文件中进行单元测试的脚本 例如,在核心脚本中引入的语法错误将无法通过karma测试,即使它没有经过单元测试
- 另外,如果脚本确实创建了任何全局变量,请在karma 中测试这些全局变量的存在
- 最终重构脚本,使其具有更多可调用单元,并在karma 中运行测试
所以从运行浏览器开始,至少要检查一下完整性!
相关文章:
- 如何动态插入jquery代码
- 如何在php变量中嵌入JQuery代码
- 将 jQuery 代码添加到 Index.aspx 页面
- jquery代码在Mozilla中有效,但在其他浏览器上无效
- Jquery:代码在rails中的页面加载时未执行
- 点击facebook像素跟踪注册(JS/JQUERY代码)
- 我的jquery代码不起作用.为什么?
- 将javascript代码转换为jquery代码时出错
- 在CodeIgniter视图中将Javascript或jQuery代码作为PHP文件编写可以吗
- 按键时停止jquery代码
- 在Grails中的gsp中执行jquery代码
- 这个jquery代码是如何工作的
- 如何在加载角度函数后运行jQuery代码
- 如何使用Javascript或jQuery代码调用mousemove
- 如何使用我的Jquery代码创建委托事件侦听器
- 为什么jQuery代码段在没有IFrame的情况下可以工作,而在有IFrame时却不能工作
- 将JQuery代码转换为等效的JavaScript代码
- JQuery代码语法问题?(“不允许内联控制结构”)
- 使用一个 jquery 代码关闭多个模态
- 如何简化动画jQuery代码