您好,登錄后才能下訂單哦!
如何理解jQuery對相關控件的事件操作,相信很多沒有經驗的人對此束手無策,為此本文總結了問題出現的原因和解決方法,通過這篇文章希望你能解決這個問題。
今天突然對他的事件產生了興趣,先前也碰到過,也沒整理,今天有空就弄一下咯。
對于控件的事件,jQuery已經提供了豐富的方法,包括綁定、一次綁定、觸發等,阿拉今早看看叫一哪能用額伐,大蝦路古就可以了。
jQuery的綁定事件非常方便,有bind、live、one還有它幫你把一些常用的事件給單獨了出來,比如控件的onclick事件,我們綁定onclick事件的時候只需要
$("#testButton").click(function() { alert("I'm Test Button"); });
就這樣我們在testButton這個按鈕上綁定了onclick事件,執行alert語句。我們也可以使用$("#testButton").click();來觸發這個onclick事件,一切都非常ok啦。以上有點sb了,接下來看看取消事件。jQuery有unbind的方法,專門來取消綁定的,也就是取消事件,按照上面的例子的話,應該使用:$("#testButton").unbind("click");恩,看上去非常好,如果你的click有2個事件的話,你還可以使用unbind("click", fnName)來刪除特定函數的綁定。為什么有這個取消特定函數的方法呢,我們來看下例子,我們會發現,javascript的事件,跟C#的事件如出一轍,事件的綁定是疊加(+=) 而不是覆蓋。
var Eat = function() { alert("我要吃飯"); } var PayMoney = function() { alert("先付錢"); } jQuery(document).ready(function() { $("#testButton").click(Eat); $("#testButton").bind("click", PayMoney); });
通過上面的例子,我們發現會先彈出:“我要吃飯”緊接著會彈出“先付錢”,說明它的綁定是通過onclick+=fn進行的。我們修改下ready的方法:
jQuery(document).ready(function() { $("#testButton").click(Eat); $("#testButton").unbind(); $("#testButton").bind("click", PayMoney); });
又出錯了,呵呵,這次點擊按鈕的話,只會執行PayMoney,不會執行Eat,那如果把unbind()放在bind后面的話,這樣這個按鈕就不會起作用了。但如果我要去掉綁定的PayMoney方法呢?這時候我們應該這樣寫:
jQuery(document).ready(function() { $("#testButton").click(Eat); $("#testButton").bind("click", PayMoney); $("#testButton").unbind("click", PayMoney); });
嘿嘿,跟bind其實一個樣,不過接下來你將看到一個bug(我不知道算不算),讓我們近距離體驗一下
:<input id="testButton" type="button" value="Test Button" onclick="Eat();" /> <script type="text/javascript"> jQuery(document).ready(function() { $("#testButton").unbind("click", Eat); $("#testButton").unbind(); $("#testButton").bind("click", PayMoney); }); </script>
大家猜猜,會顯示什么?吃飯?付錢?答案是Eat -> PayMoney,啊!!!我這里取消了綁定,又刪除了特定的綁定,為什么還會執行Eat呢?其中的原由要看jQuery的類庫了,我估計它只刪除了通過JQuery綁定的那些事件了,呵呵。那這時候我們該如何呢?好在jQuery有很多方法,其中一個就是attr,他是對Dom元素的屬性進行操作,我們利用attr來消除input上的click事件。 $("#testButton").attr("onclick", "");這樣就可以把onclick事件清除了,記住,attr上因為是元素的屬性,所以這里要寫 “onclick” 而不是click,因為click是jQuery封裝好的簡寫方式。好了,綁定就到這里了,弄個場景,大家也好記得住點:一日,老應、老趙、老陳出去吃飯,吃飽了,喝足了,準備付錢了,這時候
:<head> <script type="text/javascript" src="jquery-1.2.6.min.js"></script> <script type="text/javascript"> var PayMoney = function(name) { alert(name + ":今天我請客,我來付錢"); } jQuery(document).ready(function() { $("#JeffreyPay").attr("onclick", ""); $("#JamesPay").attr("onclick", ""); $("#JeffreyPay").click(function() { alert("。。。。這里不能刷卡"); }); $("#JeffreyPay").click(function() { PayMoney("陳大"); }); $("#JamesPay").bind("click", function() { alert("。。。。忘記帶錢包了"); }); $("#JamesPay").bind("click", $("#DlyingPay").attr("onclick")); }); </script> </head> <body> <input id="JeffreyPay" onclick="PayMoney('趙帥');" type="button" value="老趙付錢" /> <input id="JamesPay" type="button" onclick="PayMoney('老應');" value="老應付錢" /> <input id="DlyingPay" type="button" onclick="PayMoney('陳大');" value="老陳付錢" /> </body>
看完上述內容,你們掌握如何理解jQuery對相關控件的事件操作的方法了嗎?如果還想學到更多技能或想了解更多相關內容,歡迎關注億速云行業資訊頻道,感謝各位的閱讀!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。