jquery bind(click)傳參讓列表中每行綁定一個事件

點擊列表中某行,彈出詳情的需求比較常見。用jquey bind 點擊事件時,傳參不註意可能會導致點擊每一行都是顯示相同內容的情況,這大多數是因為傳參沒註意引起的問題。簡易代碼如下:

for(var i=0;i<2;i++) { 
$("#b" + i).bind("click", {'bindText':bindText + i}, function(e){ 
butClick(e); 
}); 
}

測試代碼:

<html> 
<head> 
<script type="text/javascript" src="/jquery/jquery.js"></script> 

<script type="text/javascript"> 
$(document).ready(function(){ 
var bindText = 'AAA'; 
for(var i=0;i<2;i++) { 
$("#b" + i).bind("click", {'bindText':bindText + i}, function(e){ 
butClick(e); 
}); 
} 
}); 

function butClick(e) { 
alert(e.data.bindText); 
} 
</script> 
</head> 
<body> 
<button id="b0">請點擊這裡0</button> 
<button id="b1">請點擊這裡1</button> 
</body> 
</html>

發佈留言

發佈留言必須填寫的電子郵件地址不會公開。 必填欄位標示為 *