Skip to content

Commit

Permalink
Bug #6911 - Prevent action on disabled elements, both triggering and …
Browse files Browse the repository at this point in the history
…bound via .live()
  • Loading branch information
danheberden committed Feb 18, 2011
1 parent a43a5ca commit 47abe5e
Show file tree
Hide file tree
Showing 2 changed files with 95 additions and 62 deletions.
2 changes: 1 addition & 1 deletion src/event.js
Expand Up @@ -1099,7 +1099,7 @@ function liveHandler( event ) {
for ( j = 0; j < live.length; j++ ) { for ( j = 0; j < live.length; j++ ) {
handleObj = live[j]; handleObj = live[j];


if ( close.selector === handleObj.selector && (!namespace || namespace.test( handleObj.namespace )) ) { if ( close.selector === handleObj.selector && (!namespace || namespace.test( handleObj.namespace )) && !close.elem.disabled ) {
elem = close.elem; elem = close.elem;
related = null; related = null;


Expand Down
155 changes: 94 additions & 61 deletions test/delegatetest.html
Expand Up @@ -11,63 +11,71 @@
<body> <body>
<h2>Change Tests</h2> <h2>Change Tests</h2>
<table> <table>
<tr> <tr>
<td> <td>
Change each: Change each:
</td> </td>
<td> <td>
<select class='select_test'> <select class='select_test'>
<option value='one'>change me 1</option> <option value='one'>change me 1</option>
<option value='two'>change me 2</option> <option value='two'>change me 2</option>
<option value='three'>change me 3</option> <option value='three'>change me 3</option>
</select> </select>
<select class='select_test'> <select class='select_test'>
<option value='one'>change me 1</option> <option value='one'>change me 1</option>
<option value='two' selected="selected">change me 2</option> <option value='two' selected="selected">change me 2</option>
<option value='three'>change me 3</option> <option value='three'>change me 3</option>
</select> </select>
</td> </td>
<td> <td>
<select class='mselect_test' multiple="multiple"> <select class='mselect_test' multiple="multiple">
<option value='one'>change me 1</option> <option value='one'>change me 1</option>
<option value='two'>change me 2</option> <option value='two'>change me 2</option>
<option value='three'>change me 3</option> <option value='three'>change me 3</option>
</select> </select>
</td> </td>
<td> <td>
<input type="checkbox" class="checkbox_test" name="mycheckbox" id="checkbox1"/> <input type="checkbox" class="checkbox_test" name="mycheckbox" id="checkbox1"/>
<label for="checkbox1">Checkbox 1</label><br/> <label for="checkbox1">Checkbox 1</label><br/>
<input type="checkbox" class="checkbox_test" name="mycheckbox" id="checkbox2"/> <input type="checkbox" class="checkbox_test" name="mycheckbox" id="checkbox2"/>
<label for="checkbox2">Checkbox 2</label> <label for="checkbox2">Checkbox 2</label><br />
<input type="checkbox" class="checkbox_test" name="mycheckbox" id="checkbox3" disabled="disabled"/> <input type="checkbox" class="checkbox_test" name="mycheckbox" id="checkbox3" disabled="disabled"/>
<label for="checkbox3">Checkbox 3</label> <label for="checkbox3">Checkbox 3</label>
</td> </td>
</td> <td>
</td> <button class="button_test" name="mybutton1" id="button1">Button</button><br />
<td> <button class="button_test" name="mybutton1" id="button1"><span>Button w/ child</span></button><br />
<input type="radio" class="radio_test" name="myradio" id="radio1"/> <button class="button_test" name="mybutton1" id="button1" disabled="disabled">Button Disabled</button><br />
<label for="radio1">Radio1</label><br/> <button class="button_test" name="mybutton1" id="button1" disabled="disabled"><span disabled="disabled">Button w/ child Dis.</span></button><br />
<input type="radio" class="radio_test" name="myradio" id="radio2"/> </td>
<label for="radio2">Radio2</label> <td>
<input type="radio" class="radio_test" name="myradio" id="radio3" disabled="disabled"/> <input type="radio" class="radio_test" name="myradio" id="radio1"/>
<label for="radio3">Radio3</label> <label for="radio1">Radio1</label><br/>
</td> <input type="radio" class="radio_test" name="myradio" id="radio2"/>
<td> <label for="radio2">Radio2</label><br />
<input class="file_test" id="file1" type="file"/> <input type="radio" class="radio_test" name="myradio" id="radio3" disabled="disabled"/>
<td> <label for="radio3">Radio3</label>
<input class='test' value='' id='input' size='10' /> </td>
<input class='test' value='test' id='input2' size='10' readonly="readonly" /> <td>
</td> <input class="file_test" id="file1" type="file"/>
<td> <td>
<textarea rows='2'></textarea> <input class='test' value='' id='input' size='10' />
</td> <input class='test' value='test' id='input2' size='10' readonly="readonly" />
<td>$(document).bind('change')</td> </td>
</tr> <td>
<textarea rows='2'></textarea>
</td>
</td>
<td>$(document).bind('change')<br />
$(document).bind('click')
</td>
</tr>
<tr> <tr>
<td>Live:</td> <td>Live:</td>
<td id='select' class="red">SELECT</td> <td id='select' class="red">SELECT</td>
<td id='mselect' class="red">MULTI</td> <td id='mselect' class="red">MULTI</td>
<td id='checkbox' class="red">CHECKBOX</td> <td id='checkbox' class="red">CHECKBOX</td>
<td id='button' class="red">BUTTON</td>
<td id='radio' class="red">RADIO</td> <td id='radio' class="red">RADIO</td>
<td id='file' class="red">FILE</td> <td id='file' class="red">FILE</td>
<td id='text' class="red">TEXT</td> <td id='text' class="red">TEXT</td>
Expand All @@ -79,6 +87,7 @@ <h2>Change Tests</h2>
<td id='selectbind' class="red">SELECT</td> <td id='selectbind' class="red">SELECT</td>
<td id='mselectbind' class="red">MULTI</td> <td id='mselectbind' class="red">MULTI</td>
<td id='checkboxbind' class="red">CHECKBOX</td> <td id='checkboxbind' class="red">CHECKBOX</td>
<td id='buttonbind' class="red">BUTTON</td>
<td id='radiobind' class="red">RADIO</td> <td id='radiobind' class="red">RADIO</td>
<td id='filebind' class="red">FILE</td> <td id='filebind' class="red">FILE</td>
<td id='textbind' class="red">TEXT</td> <td id='textbind' class="red">TEXT</td>
Expand All @@ -89,6 +98,7 @@ <h2>Change Tests</h2>
<td id='selectfocus' class="red">SELECT</td> <td id='selectfocus' class="red">SELECT</td>
<td id='mselectfocus' class="red">MULTI</td> <td id='mselectfocus' class="red">MULTI</td>
<td id='checkboxfocus' class="red">CHECKBOX</td> <td id='checkboxfocus' class="red">CHECKBOX</td>
<td id='buttonfocus' class="red">BUTTON</td>
<td id='radiofocus' class="red">RADIO</td> <td id='radiofocus' class="red">RADIO</td>
<td id='filefocus' class="red">FILE</td> <td id='filefocus' class="red">FILE</td>
<td id='textfocus' class="red">TEXT</td> <td id='textfocus' class="red">TEXT</td>
Expand All @@ -100,6 +110,7 @@ <h2>Change Tests</h2>
<td id='selectblur' class="red">SELECT</td> <td id='selectblur' class="red">SELECT</td>
<td id='mselectblur' class="red">MULTI</td> <td id='mselectblur' class="red">MULTI</td>
<td id='checkboxblur' class="red">CHECKBOX</td> <td id='checkboxblur' class="red">CHECKBOX</td>
<td id='buttonblur' class="red">BUTTON</td>
<td id='radioblur' class="red">RADIO</td> <td id='radioblur' class="red">RADIO</td>
<td id='fileblur' class="red">FILE</td> <td id='fileblur' class="red">FILE</td>
<td id='textblur' class="red">TEXT</td> <td id='textblur' class="red">TEXT</td>
Expand All @@ -111,6 +122,7 @@ <h2>Change Tests</h2>
<td id='selectlfocus' class="red">SELECT</td> <td id='selectlfocus' class="red">SELECT</td>
<td id='mselectlfocus' class="red">MULTI</td> <td id='mselectlfocus' class="red">MULTI</td>
<td id='checkboxlfocus' class="red">CHECKBOX</td> <td id='checkboxlfocus' class="red">CHECKBOX</td>
<td id='buttonlfocus' class="red">BUTTON</td>
<td id='radiolfocus' class="red">RADIO</td> <td id='radiolfocus' class="red">RADIO</td>
<td id='filelfocus' class="red">FILE</td> <td id='filelfocus' class="red">FILE</td>
<td id='textlfocus' class="red">TEXT</td> <td id='textlfocus' class="red">TEXT</td>
Expand All @@ -121,11 +133,24 @@ <h2>Change Tests</h2>
<td id='selectlblur' class="red">SELECT</td> <td id='selectlblur' class="red">SELECT</td>
<td id='mselectlblur' class="red">MULTI</td> <td id='mselectlblur' class="red">MULTI</td>
<td id='checkboxlblur' class="red">CHECKBOX</td> <td id='checkboxlblur' class="red">CHECKBOX</td>
<td id='buttonlblur' class="red">BUTTON</td>
<td id='radiolblur' class="red">RADIO</td> <td id='radiolblur' class="red">RADIO</td>
<td id='filelblur' class="red">FILE</td> <td id='filelblur' class="red">FILE</td>
<td id='textlblur' class="red">TEXT</td> <td id='textlblur' class="red">TEXT</td>
<td id='textarealblur' class="red">TEXTAREA</td> <td id='textarealblur' class="red">TEXTAREA</td>
</tr> </tr>
<tr>
<td>Live Click:</td>
<td id='selectlclick' class="red">SELECT</td>
<td id='mselectlclick' class="red">MULTI</td>
<td id='checkboxlclick' class="red">CHECKBOX</td>
<td id='buttonlclick' class="red">BUTTON</td>
<td id='radiolclick' class="red">RADIO</td>
<td id='filelclick' class="red">FILE</td>
<td id='textlclick' class="red">TEXT</td>
<td id='textarealclick' class="red">TEXTAREA</td>
<td id='boundClick' class="red">DOCUMENT</td>
</tr>
</table> </table>
<h2>Submit Tests</h2> <h2>Submit Tests</h2>
<table> <table>
Expand Down Expand Up @@ -162,7 +187,7 @@ <h2>Submit Tests</h2>
<ul id="log"></ul> <ul id="log"></ul>


<script type='text/javascript'> <script type='text/javascript'>
jQuery.fn.addChangeTest = function( id, prevent ) { jQuery.fn.addChangeClickTest = function( id, prevent ) {
this.bind("focusin", function(){ this.bind("focusin", function(){
jQuery(id + "focus").blink(); jQuery(id + "focus").blink();
}).bind("focusout", function(){ }).bind("focusout", function(){
Expand All @@ -183,9 +208,12 @@ <h2>Submit Tests</h2>
} }


jQuery(id).blink(); jQuery(id).blink();
}); }).live("click", function(e){
jQuery(id + "lclick").blink();
});
}; };



jQuery.fn.addSubmitTest = function( id, prevent ) { jQuery.fn.addSubmitTest = function( id, prevent ) {
return this.live("submit", function(e){ return this.live("submit", function(e){
if ( prevent ) { if ( prevent ) {
Expand All @@ -210,6 +238,10 @@ <h2>Submit Tests</h2>
$(document).bind("focusout", function() { $(document).bind("focusout", function() {
jQuery("#boundBlur").blink(); jQuery("#boundBlur").blink();
}); });

$(document).bind("click", function() {
jQuery("#boundClick").blink();
});


$("td.red").live("hover", function(e) { $("td.red").live("hover", function(e) {
if ( e.type === "mouseenter" ) { if ( e.type === "mouseenter" ) {
Expand All @@ -219,13 +251,14 @@ <h2>Submit Tests</h2>
} }
}); });


$(".select_test").addChangeTest("#select"); $(".select_test").addChangeClickTest("#select");
$(".mselect_test").addChangeTest("#mselect"); $(".mselect_test").addChangeClickTest("#mselect");
$(".checkbox_test").addChangeTest("#checkbox"); $(".checkbox_test").addChangeClickTest("#checkbox");
$(".radio_test").addChangeTest("#radio"); $(".radio_test").addChangeClickTest("#radio");
$(".file_test").addChangeTest("#file"); $(".file_test").addChangeClickTest("#file");
$('textarea').addChangeTest("#textarea"); $('textarea').addChangeClickTest("#textarea");
$('#input').addChangeTest("#text"); $('#input').addChangeClickTest("#text");
$('button').addChangeClickTest("#button");
$(document).bind("change", function(){ $(document).bind("change", function(){
jQuery("#boundChange").blink(); jQuery("#boundChange").blink();
}); });
Expand Down

0 comments on commit 47abe5e

Please sign in to comment.