首先,我只是想说下面的代码在现实中起作用。它只是在茉莉花规格中失败了。功能很简单。选中ID为“check_all”的复选框时,也请选中所有其他复选框。
当我运行测试时,所有包括期望#check_all为true的内容都按预期传递。我无法理解为什么我的所有期望都没有通过。有什么建议吗?
功能:
window.check_all = () ->
$('#check_all').change(->
if $('#check_all').is(':checked')
$('.checkbox').attr('checked', 'checked')
else
$('.checkbox').removeAttr('checked')
)
$(check_all)
测试:
describe 'checkbox', ->
beforeEach ->
loadFixtures 'checkbox'
describe 'check_all', ->
it 'checks all the checkboxes if check_all is checked', ->
expect($('#check_all').is(':checked')).toBeFalsy()
expect($('#question_1').is(':checked')).toBeFalsy()
expect($('#question_2').is(':checked')).toBeFalsy()
expect($('#question_3').is(':checked')).toBeFalsy()
expect($('#question_4').is(':checked')).toBeFalsy()
expect($('#question_5').is(':checked')).toBeFalsy()
$('#check_all').attr('checked', 'checked')
$('#check_all').change()
expect($('#check_all').is(':checked')).toBeTruthy()
expect($('#question_1').is(':checked')).toBeTruthy()
expect($('#question_2').is(':checked')).toBeTruthy()
expect($('#question_3').is(':checked')).toBeTruthy()
expect($('#question_4').is(':checked')).toBeTruthy()
expect($('#question_5').is(':checked')).toBeTruthy()
夹具:
<p class="small gray"><input type="checkbox" name="check_all" id="check_all"> Select All</p>
<form accept-charset="UTF-8" action="" method="post">
<ul class="library_questions">
<li>
<input class="checkbox" id="question_1" name="question[]" type="checkbox" value="1"/>
Template Q1
</li>
<li>
<input class="checkbox" id="question_2" name="question[]" type="checkbox" value="2"/>
Template Q2
</li>
<li>
<input class="checkbox" id="question_3" name="question[]" type="checkbox" value="3"/>
Template Q3
</li>
<li>
<input class="checkbox" id="question_4" name="question[]" type="checkbox" value="4"/>
Template Q4
</li>
<li>
<input class="checkbox" id="question_5" name="question[]" type="checkbox" value="5"/>
Instructions
</li>
</ul>
<input class="purple submit_button" name="commit" type="submit" value="Submit"/>
</form>
答案 0 :(得分:4)
您正在从check_all
函数运行$
,这意味着它在文档就绪事件之后运行。我猜你的测试运行得更早,这就是为什么触发change
事件不会影响复选框的原因。所以,要么:
$
包装器或check_all
中定义<body>
的脚本放在$
的末尾。然后您根本不需要使用change
包装器。第三种选择是在#check_all
的祖先上绑定$(document).on('change', '#check_all', -> ...)
事件处理程序。例如,
live
(在jQuery 1.7之前,您使用的是on
而不是<head>
。)这样,即使您的脚本从$
运行,您仍然不需要{ {1}}包装。