點擊列表中某行,彈出詳情的需求比較常見。用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>