js中关于某个对象是否有某个属性的判断

JavaScript016

js中关于某个对象是否有某个属性的判断,第1张

正确使用判断对象是否存在应该用: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。

直接用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

使用attr()方法来实现

我们可以使用attr()来设置属性,比如设置为只读:

$("#id").attr("disabled",true)

反之,可以通过获取属性值来判断指定属性是否存在

if(typeof($("#id").attr("rel"))=="undefined")

{

//不存在执行

}else{

//存在执行

}