zoukankan      html  css  js  c++  java
  • JavaScript中的可枚举属性与不可枚举属性

    https://www.cnblogs.com/kongxy/p/4618173.html

        在JavaScript中,对象的属性分为可枚举和不可枚举之分,它们是由属性的enumerable值决定的。可枚举性决定了这个属性能否被for…in查找遍历到。

    一、怎么判断属性是否可枚举

      js中基本包装类型的原型属性是不可枚举的,如Object, Array, Number等,如果你写出这样的代码遍历其中的属性:

    1
    2
    3
    4
    var num = new Number();
    for(var pro in num) {
        console.log("num." + pro + " = " + num[pro]);
    }

    它的输出结果会是空。这是因为Number中内置的属性是不可枚举的,所以不能被for…in访问到。

    Object对象的propertyIsEnumerable()方法可以判断此对象是否包含某个属性,并且这个属性是否可枚举。

    需要注意的是:如果判断的属性存在于Object对象的原型内,不管它是否可枚举都会返回false。

    二、枚举性的作用

    属性的枚举性会影响以下三个函数的结果:

    for…in

    Object.keys()

    JSON.stringify

    先看一个例子,按如下方法创建kxy对象:

    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    function Person() {
        this.name = "KXY";
    }
    Person.prototype = {
        constructor: Person,
        job: "student",
    };
     
    var kxy = new Person();
    Object.defineProperty(kxy, "sex", {
        value: "female",
        enumerable: false
    });

    其中用defineProperty为对象定义了一个名为”sex”的不可枚举属性

    接下来做以下验证:

    1.

    1
    2
    3
    for(var pro in kxy) {
        console.log("kxy." + pro + " = " + kxy[pro]);
      }

    遍历结果:

    kxy.name = KXY

    kxy.constructor = function Person() {
    this.name = "KXY";
    }
    kxy.job = student

    可以看到除了”sex“之外的属性都遍历到了

    [ 个人补充

      for(var pro in kxy) {
        if(kxy.hasOwnProperty(pro)) console.log("kxy." + pro + " = " + kxy[pro]);
      }
      打印结果是:

      kxy.name = KXY

    ]

    2.

    1
    console.log(Object.keys(kxy));

    结果:

    枚举性检验2

    只包含”name”属性,说明该方法只能返回对象本身具有的可枚举属性。

    3.

    1
    console.log(JSON.stringify(kxy));

    <结果:

    可枚举性检验3

    此方法也只能读取对象本身的可枚举属性,并序列化为JSON对象。

  • 相关阅读:
    oracle安装过程中遇到的问题
    HttpContext.Current 的缺陷
    oracle 复杂语句
    .net 中 ref out params的区别
    查看修改mysql编码方式[转载]
    Oracle 中的dual是什么东西
    KindEditor问题汇总【不定时更新】
    java中import、package作用和用法
    [笔记]: 哈弗曼树(最优二叉树) 标签: 二叉树 2017-05-17 16:38 34人阅读 评论(0) 收
    [noip 2004普及组] FBI树 标签: 二叉树递归 2017-05-17 14:29 40人阅读 评论(0)
  • 原文地址:https://www.cnblogs.com/jcz1206/p/9553115.html
Copyright © 2011-2022 走看看