正确使用判断对象是否存在应该用:if($("#id").length>0){}else{}使用jQuery 对象的属性 length 来判断,如果 >0 就存在。或者 if($("#id")[0]){} else {} 或者直接使用原生的 Javascript 代码来判断: if(document.getElementByIdx_x_xx_x("id")){} else {}或者var g = document.getElementByIdif (g('addrId_324') != null) { //判断是否存在这个id号,不存在则为null g('addrId_' + selAddressId).className = ''} JQuery 判断某个属性是否存在 hasAttr在JQuery编码中,我们会判断元素是否存在某个属性.比如是否包含 class="new"的样式呢.JQuery判断就非常简单了,因为有hasClass这个方法 $("input[name=new]").hasClass("new") 即可判断.这时就没有现成的方法了. 如果存在某个属性 $("#aid").attr("rel") 会返回 rel的值,如果不存在 rel属性则会返回"undefined"undefined 就是 undefined类型 , if($("#aid").attr("rel")=="undefined") 这个判断可能不成立.因为类型不相同.建议使用 if(typeof($("#aid").attr("rel"))=="undefined") 即可判断JS对象是否拥有某属性两种方式,但稍有区别1,in 运算符123varobj = {name:'jack'}alert('name'inobj)// -->truealert('toString'inobj)// -->true可看到无论是name,还是原形链上的toString,都能检测到返回true。 2,hasOwnProperty 方法?123varobj = {name:'jack'}obj.hasOwnProperty('name')// -->trueobj.hasOwnProperty('toString')// -->false原型链上继承过来的属性无法通过hasOwnProperty检测到,返回false。可以用数组的indexOf函数,方法arr.indexOf(find,start)
find:要找的内容,必须;
start:查找开始下标,可选;
返回:查找数据所在的下标,如果没找到,返回-1
如果只要知道是否有8这个数字,直接调用arr.indexOf(8),如果返回值不为-1,说明找到了
var s=[1,2,3,5,6,9]
var u=s.indexOf(5)//返回5所在的下标3
var d=s.indexOf(8)//返回-1
console.log(u)
console.log(d)
直接用jq获取:
if($(".class").attr("style")){
//存在
}
解释:
1、$(".class").attr("style")写在if条件里面:
如果$(".class").attr("style")不存在时,那在if里面返回的是undefind。
undefind就是表示不存在(空对象)的意思,不存在即表示false,如果存在,那返回的就是true
2、$(".class").attr("style")用一个变量接收时:
var _style=$(".class").attr("style")如果存在style属性,那_style就是style的具体的值,如果不存在,那_style就是undefind