如何区分JavaScript中的可枚举属性和不可枚举属性?

2026-04-02 08:551阅读0评论SEO资讯
  • 内容介绍
  • 文章标签
  • 相关推荐

本文共计811个文字,预计阅读时间需要4分钟。

如何区分JavaScript中的可枚举属性和不可枚举属性?

在JavaScript中,对象的属性分为可枚举和不可枚举两类,这是由属性的`enumerable`值决定的。可枚举性决定了这个属性是否可以被`for...in`循环遍历到。

一、如何判断属性是否可枚举在JavaScript中,可以通过`Object.prototype.propertyIsEnumerable()`方法来判断一个属性是否可枚举。这个方法接收一个属性名作为参数,如果该属性是可枚举的,则返回`true`,否则返回`false`。

示例代码:javascriptvar obj={ name: 'example'};

console.log(Object.prototype.propertyIsEnumerable.call(obj, 'name')); // 输出:trueconsole.log(Object.prototype.propertyIsEnumerable.call(obj, 'toString')); // 输出:false

二、`Object.prototype`包`Object.prototype`是所有对象的原型,它包含了所有对象共有的属性和方法。例如,`toString()`、`valueOf()`、`hasOwnProperty()`等。在上述示例中,`toString`方法就是从`Object.prototype`继承而来的,因此不可枚举。

总结:

1.可枚举性由属性的`enumerable`值决定。

2.使用`Object.prototype.propertyIsEnumerable()`方法可以判断属性是否可枚举。

3.`Object.prototype`包含了所有对象共有的属性和方法,这些属性通常是不可枚举的。

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

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

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

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对象:

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”的不可枚举属性

接下来做以下验证:

如何区分JavaScript中的可枚举属性和不可枚举属性?

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

遍历结果:

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

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

结果:

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

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

结果:

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

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持易盾网络。

本文共计811个文字,预计阅读时间需要4分钟。

如何区分JavaScript中的可枚举属性和不可枚举属性?

在JavaScript中,对象的属性分为可枚举和不可枚举两类,这是由属性的`enumerable`值决定的。可枚举性决定了这个属性是否可以被`for...in`循环遍历到。

一、如何判断属性是否可枚举在JavaScript中,可以通过`Object.prototype.propertyIsEnumerable()`方法来判断一个属性是否可枚举。这个方法接收一个属性名作为参数,如果该属性是可枚举的,则返回`true`,否则返回`false`。

示例代码:javascriptvar obj={ name: 'example'};

console.log(Object.prototype.propertyIsEnumerable.call(obj, 'name')); // 输出:trueconsole.log(Object.prototype.propertyIsEnumerable.call(obj, 'toString')); // 输出:false

二、`Object.prototype`包`Object.prototype`是所有对象的原型,它包含了所有对象共有的属性和方法。例如,`toString()`、`valueOf()`、`hasOwnProperty()`等。在上述示例中,`toString`方法就是从`Object.prototype`继承而来的,因此不可枚举。

总结:

1.可枚举性由属性的`enumerable`值决定。

2.使用`Object.prototype.propertyIsEnumerable()`方法可以判断属性是否可枚举。

3.`Object.prototype`包含了所有对象共有的属性和方法,这些属性通常是不可枚举的。

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

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

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

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对象:

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”的不可枚举属性

接下来做以下验证:

如何区分JavaScript中的可枚举属性和不可枚举属性?

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

遍历结果:

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

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

结果:

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

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

结果:

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

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持易盾网络。