jquery – 我们如何对DOM操作执行单元测试?

netTuts.com的QUnit over的介绍产生了一个有趣的交换(从未解决)如何对操纵DOM的操作应用单元测试.以下引用(Alex York)得到了关键:

What would be nice is that if you had
a function like this:

function add(a,b) { var result = a +
b;
$(“input#ResultTestBox”).val(result);

In the above test,I would love to
test two things: the addition of a and
b,and the result correctly being put
into a DOM element. I would love to
test the second thing by providing
some mock HTML. Possible?

但是,就像我说的…没有解决.可分解?

解决方法

最新版本的QUnit支持#qunit-fixture元素,可以将HTML添加到QUnit网页.

例如,在你的HTML中:

<ol id="qunit-tests"></ol>
<div id="qunit-fixture">test markup,will be hidden</div>

并在您的JavaScript中:

$('<input id="ResultTestBox" type="text"/>').appendTo('#qunit-fixture');
var result = add(a,b);

equals(result,$('input#ResultTestBox').val(),"testing result Box value");

相关文章

jQuery插件的种类 1、封装对象方法 这种插件是将对象方法封装起来,用于对通过选择器获取的jQuery对象进...
扩展jQuery插件和方法的作用是非常强大的,它可以节省大量开发时间。 入门 编写一个jQuery插件开始于给...
最近项目中需要实现3D图片层叠旋转木马切换的效果,于是用到了jquery.roundabout.js。 兼容性如图: ht...
一、什么是deferred对象? 开发网站的过程中,我们经常遇到某些耗时很长的javascript操作。其中,既有异...
AMD 模块 AMD(异步模块定义,Asynchronous Module Definition)格式总体的目标是为现在的开发者提供一...