Okay so, I'm wondering how to unbind an inline onclick event in jQuery. You'd think .unbind()
would work, however it doesn't.
To test this for yourself, play around with the following HTML and JavaScript:
function UnbindTest() { $("#unbindTest").unbind('click'); } function BindTest() { $("#unbindTest").bind('click', function() { alert("bound!"); }); } <button type="button" onclick="javascript:UnbindTest();">Unbind Test</button> <button type="button" onclick="javascript:BindTest();">Bind Test</button> <button type="button" onclick="javascript:alert('unbind me!');" id="unbindTest">Unbind Button</button>
As you can see, unbinding does not unbind the inline onclick
event... however it does unbind the click event added with bind()
.
So, I'm wondering if there is a way to unbind inline onclick events short of doing the following:
$("#unbindTest").get(0).onclick = "";
Thanks
jQuery's unbind won't work on onclick
attributes - it only works for functions that were added via bind
and thus are available in $(...).data('events')
. You have to use removeAttr
to remove onclick
.
Read this question for more info.
If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!
Donate Us With