判断JS对象是否拥有某属性

JavaScript031

判断JS对象是否拥有某属性,第1张

第一种,判断js对象中是否有某个属性

var obj = {test : 'test'}

if('test' in obj){

    console.log('yes')

} else {

    console.log('no')

}

第二种,判断js对象本身是否有某个属性(所谓本身有意思是,必须属性是直接在对象上的,而不是通过原型链上找到的。

var Base = function(){}

Base.prototype.test = 'test'

var obj = new Base()

obj.test2 = 'test2'

if('test1' in obj){

    console.log('yes')

} else {

    console.log('no')

}

if(obj.hasOwnProperty('test2')){

    console.log('own')

} else {

    console.log('none')

}

//用in 操作符,可以判断有没有。 用hasOwnProperty来判断在自身有没有。

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