首頁  >  文章  >  web前端  >  jQuery中 delegate使用的問題_jquery

jQuery中 delegate使用的問題_jquery

WBOY
WBOY原創
2016-05-16 15:51:331026瀏覽

習慣了bind,用慣了live,就不習慣delegate了呀有木有...

支援為動態產生的標籤元素綁定事件也許就live和delegate了吧,不過新版本已經不支援live了,只有delegate

delegate真的比較特殊呀,不同於其他事件綁定的風格。

就因為習慣了之前的bind風格..栽了跟頭

簡單的說就是大意了。

delegate() 方法為指定的元素(屬於被選元素的子元素)新增一個或多個事件處理程序,並規定當這些事件發生時執行的函數。

使用 delegate() 方法的事件處理程序適用於目前或未來的元素(例如由腳本建立的新元素)。

文法

$(selector).delegate(childSelector,event,data,function)

參數 描述
childSelector 必需。規定要附加事件處理程序的一個或多個子元素。
event

必需。規定附加到元素的一個或多個事件。

由空格分隔多個事件值。必須是有效的事件。

data 可选。规定传递到函数的额外数据。
function 必需。规定当事件发生时运行的函数。

比如这段小代码啊

<html>
<head>
<script type="text/javascript" src="/jquery/jquery.js"></script>
<script type="text/javascript">
$(document).ready(function(){
 $("div").delegate("button","click",function(){
  $("p").slideToggle();
 });
});
</script>
</head>
<body>
<div style="background-color:red">
<p>这是一个段落。</p>
<button>请点击这里</button>
</div>

</body>
</html>

我老写成了

$(document).ready(function(){
 $("div").delegate($("button"),"click",function(){
  $("p").slideToggle();
 });
});

子选择器不需要选择起来了..

不然就像我那样出现不知名的错误(点击会触发click,但点击其他元素也会触发click...)

以上所述就是本文的全部内容了,希望大家能够喜欢。

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn