当前位置:编程学习 > JAVA >>

jquery.each兼容IE,firefox

jQuery的each 方法中的this指针指向问题,这个是昨天工作中遇到的问题

jQuery.each  写法:
1 :
Java代码 
 
jQuery('input[type=checkbox]').each(function (){  
 
        alert(this.checked+this.treeId);//treeI的是自定义属性  
}); 


jQuery('input[type=checkbox]').each(function (){

        alert(this.checked+this.treeId);//treeI的是自定义属性
});


这样的写法在IE下会正常的输出,但是在firefox,则不会识别,尤其是对于自定义属性,this指针在闭包的时候出现差错。

2:
Java代码 
jQuery.each(jQuery('input[type=checkbox]'),function (i,item){  
        alert("i=" + i + ",item="+jQuery(item).attr('自定义属性'));  
}); 

jQuery.each(jQuery('input[type=checkbox]'),function (i,item){
        alert("i=" + i + ",item="+jQuery(item).attr('自定义属性'));
});


这样写就会避免使用this指针,就可以兼容ie和firefox了,i是代表当前是第几个变量,而item则代表这个变量所指的对象,是dom对象

所以我个人建议以后我们用jQuery 的each 方法 都用 第二种写法

补充:web前端 , JavaScript ,
CopyRight © 2022 站长资源库 编程知识问答 zzzyk.com All Rights Reserved
部分文章来自网络,