• JS propertyIsEnumerable()方法:检测一个属性是否可枚举

    JavaScript propertyIsEnumerable() 是 Object 原型方法(也称实例方法),它定义在 Object.prototype 对象之上,所有 Object 的实例对象都会继承 propertyIsEnumerable() 方法。

    propertyIsEnumerable() 方法用来检测一个属性是否可枚举,如果是就返回 true,否则就返回 false。

    如果一个属性同时满足以下两个条件,我们就称它为可枚举属性:

    • 该属性是对象的自有属性。也就是对象本身就包含该属性,而不是从原型链继承而来。使用 hasOwnProperty() 方法可以检测自有属性。
    • 该属性是自定义的,而不是内置的,可以通过 for in 循环列举出来。

    propertyIsEnumerable() 的语法格式如下:

    object.propertyIsEnumerable("propertyName");

    参数说明:propertyName 参数表示要检测的属性名称。

    返回值:propertyIsEnumerable() 方法的返回值为 Boolean 类型。如果 propertyName 是可枚举属性,那么返回 true,否则返回 false。

    在大多数情况下,使用 in 运算符是探测对象中属性是否存在的最好途径。然而在某些情况下,可能希望仅在当一个属性是自有属性时才检查其是否存在。in 运算符会检查自有属性和原型属性,所以不得不选择hasOwnProperty() 方法。

    var person = {
        'first-name' : 'zhang',
        'last-name' : 'san',
        sayName : function () {
            console.log(this['first-name'] + this['last-name']);
        }
    };
    console.log('first-name' in person);  //true
    console.log(person.hasOwnProperty('first-name'));  //true
    console.log('toString' in person);  //true
    console.log(person.hasOwnProperty('toString'));  //false

    示例1

    for/in 语句可用来遍历一个对象中的所有属性名,该枚举过程将会列出所有的属性,包括原型属性和自有属性。很多情况下需要过滤一些不想要的值,如方法或原型属性。最为常用的过滤器是 hasOwnProperty 方法,也可以使用 typeof 运算符进行排除。

    for (var name in person) {
        if (typeof person[name] != 'function') {  //排除所有方法
            console.log(name + ':' + person[name]);
        }
    }

    使用 for/in 语句枚举,属性名出现的顺序是不确定的,最好的办法就是完全避免使用 for/in 语句,可以创建一个数组,在其中以正确的顺序包含属性名。通过使用 for/in 语句,可以不用担心可能会出现原型属性,并且按正确的顺序取得它们的值。

    var properties = ['sayName', 'first-name', 'last-name'];  //使用数组定义枚举顺序
    for (var i = 0; i < properties.length; i ++) {
        console.log(properties[i] + ':' + person[properties[i]]);
    }

    对于 JavaScript 对象来说,用户可以使用 for/in 语句遍历一个对象“可枚举”的属性。但并不是所有对象属性都可以枚举,只有用户自定义的自有属性和原型属性才允许枚举。

    示例2

    对于下面的自定义对象 o,使用 for/in 循环可以遍历它的所有自有属性、原型属性,但是 JavaScript 允许枚举的属性只有 a、b 和 c。

    function F() {
        this.a = 1;
        this.b = 2;
    }
    F.prototype.c = 3;
    F.d = 4;
    var o = new F();
    for (var I in o) {
        console.log(I);
    }

    示例3

    为了判定指定自有属性是否允许枚举,Object 对象定义了 propertyIsEnumerable() 方法。该方法的返回值为 true,则说明指定的自有属性可以枚举,否则是不允许枚举的。

    console.log(o.propertyIsEnumerable("a"));  //返回值为true,说明可以枚举
    console.log(o.propertyIsEnumerable("b"));  //返回值为true,说明可以枚举
    console.log(o.propertyIsEnumerable("c"));  //返回值为false,说明不可以枚举
    console.log(o.propertyIsEnumerable("d"));  //返回值为false,说明不可以枚举
    var o = F;
    console.log(o.propertyIsEnumerable("d"));  //返回值为true,说明可以枚举

更多...

加载中...