jquery bind(click)传参让列表中每行绑定一个事件
点击列表中某行,弹出详情的需求比较常见。用jqueybind点击事件时,传参不注意可能会导致点击每一行都是显示相同内容的情况,这大多数是因为传参没注意引起的问题。简易代码如下:
for(vari=0;i<2;i++){ $("#b"+i).bind("click",{'bindText':bindText+i},function(e){ butClick(e); }); }
测试代码:
<html> <head> <scripttype="text/javascript"src="/jquery/jquery.js"></script> <scripttype="text/javascript"> $(document).ready(function(){ varbindText='AAA'; for(vari=0;i<2;i++){ $("#b"+i).bind("click",{'bindText':bindText+i},function(e){ butClick(e); }); } }); functionbutClick(e){ alert(e.data.bindText); } </script> </head> <body> <buttonid="b0">请点击这里0</button> <buttonid="b1">请点击这里1</button> </body> </html>