欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

javascript动态创建对象的属性详解

程序员文章站 2023-10-27 23:28:22
面向对象的javascript在客户端编码时提供了极大的灵活性,javascript对象上的属性有助于设置可在对象内使用以管理和使用数据的值。 我对javascrip...

面向对象的javascript在客户端编码时提供了极大的灵活性,javascript对象上的属性有助于设置可在对象内使用以管理和使用数据的值。

我对javascript中属性的理解,在javascript中,可以通过在文字对象上定义变量来创建属性。

例如

var obj = {
  property1: '',
  property2: ''
  };

现在可以通过使用来访问这些属性

obj.property1 = 'some value';
obj.property2 = 'some other value';

同样,类似地,它们也可以在对象object内的函数内使用。

例如:

var obj = {
  property1: '',
  property2: '',
  foo : function(){
      console.log(obj.property1);
  }};

现在我们知道如何在javascript对象上创建属性,让我们看看如何在javascript上创建动态属性

有两种方法可以做到这一点

在javascript对象上定义类似于array的动态属性

让我们采用与上面相同的例子:

var obj = {
  property1: '',
  property2: ''
  };

在对象objo上创建动态属性,我们可以这样做:

obj['property_name'] = 'some_value';

它的作用是,它在对象上创建一个obj新属性可以访问它作为console.log(obj.property_name);

这将在控制台上输出值some_value

使用object.defineproperty定义动态属性。

例:

// example of an object property added with defineproperty with a data property descriptor
object.defineproperty(obj, "property3", {value : 'some value',
              writable : true,
              enumerable : true,
              configurable : true});
// 'property3' property exists on object obj and its value is 37