JS中的对象枚举

for in 循环

遍历对象属性的循环。通过对象属性的个数来控制循环圈数,每一圈将对象的属性名赋值给变量prop ( String类型 )。prop–property

格式:for( xx in obj) { }

    var obj = {
        a : 1,
        b : 2,
        c : 3
    }

    for(var prop in obj){
        console.log(obj[prop]);
    }

    //控制台输出:1 2 3

补充:理论上来说,for in 循环可以返回原型和原型链上的东西,但是一旦原型链延展到了 Object.prototype,就不会返回。

hasOwnProperty()

一种过滤性方法,判断对象是否存在xx属性,不会访问原型。返回bool值true / false。通常与for in循环连用。

格式:obj.hasOwnPorperty ( prop )

    var obj = {
        a : 1,
        b : 2,
        c : 3,
        //加入__proto__属性
        __proto__ : { name : "abc" }
    }

    for(var prop in obj){
        //判断是否是自身的属性,若是则输出
        if(obj.hasOwnProperty(prop)){
            console.log(obj[prop]);
        }
    }

    //控制台输出:1 2 3

__ proto __ 属于原型属性,调用该方法的返回值为false,故不输出。

in

in与hasOwnProperty()类似,侧重于判断对象能否访问到xx属性(包括原型)。
不同点:in在进行判断时,会访问到对象自己的属性,还会访问对象原型的属性。in使用频率很低。

‘height’ in obj;
返回false;

instanceof

用法与in类似。

格式:A instanceof B

判断A对象是不是B构造函数构造出来的。可以理解为判断A对象的原型链上有没有B的原型。返回bool值。

    function Person(){}
    var person = new Person();

    console.log(person instanceof Person);  //输出true
    console.log(person instanceof Object);  //输出true
    console.log([] instanceof Array);       //输出true
    console.log([] instanceof Object);      //输出true
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值