Object

La clase Object representa uno de los tipos de datos en Javascript. Es usado para guardar una colección de datos definidos y entidades más complejas. Los objetos pueden ser creados utilizando el constructor Object() o la sintaxis literal / inicializador de objeto.

Descripción

Casi todos los objetos en JavaScript son instancias de Object; un objeto típico hereda propiedades (incluyendo los métodos) de Object.prototype, a pesar de que esas propiedades puedan ser sobreescritas. Aun así, un Object puede ser deliberadamente creado para que esto no se cumpla (por ejemplo con Object.create(null)), o puede alterarse para que esto no sea más verdad (por ejemplo con Object.setPrototypeOf).

Los cambios realizados en el Object prototipo son vistos por todos los objetos de la cadena de prototipos, a no ser que las propiedades y métodos sujetos a esos cambios hayan sido sobreescritos más abajo en la cadena. Sobreescribir o extender el comportamiento de un objeto es un mecanismo muy poderoso, aunque potencialmente peligroso.

El constructor Objeto crea un envoltorio de objeto para el valor dado.

  • Si el valor es null o undefined, se creará un objeto y se retornará un objeto vacío.
  • Si el valor ya es un objeto, entonces se retornará el valor.
  • En cualquier otro caso, se retornará un objeto del Tipo que corresponda al valor dado.

Cuando lo llamamos en un contexto no-constructivo, Object se comporta igual que new Object().

Véase también la la sintaxis literal / inicializador de objeto.

Borrando una propiedad de un objeto

No hay ningún método en un Objeto que sirva para borrar sus propiedades (como Map.prototype.delete()). Para hacerlo, es necesario el uso del operador delete.

Constructor

Object()

Crea un nuevo objeto Object. Este es un envoltorio para el valor dado.

Métodos estáticos

Object.assign()

Copia los valores de todas las propiedades enumerables propias de uno o más objetos fuente al objeto asignado.

Object.create()

Crea un nuevo objeto con el objeto prototipal especificado y sus propiedades.

Object.defineProperty()

Agrega la propiedad nombrada descrita por el descriptor dado a un objeto.

Object.defineProperties()

Añade las propiedades nombradas a un objeto.

Object.entries()

Devuelve un array que contiene todos los pares [key, value] de las propiedades enumerables en formato cadena de texto que le pertenecen a un objeto dado.

Object.freeze()

Congela un objeto. Otro código no puede borrar ni cambiar sus propiedades.

Object.fromEntries()

Devuelve un nuevo objeto de los pares iterables [key, value]. (Este método hace lo contrario a Object.entries).

Object.getOwnPropertyDescriptor()

Devuelve un descriptor de propiedad para una propiedad nombrada en un objeto.

Object.getOwnPropertyDescriptors()

Devuelve un objeto con todos los descriptores de propiedad pertenecientes a un objeto.

Object.getOwnPropertyNames()

Devuelve un arreglo que contiene todos los nombres de las propiedades enumerables y no enumerables que le pertenecen a un objeto dado.

Object.getOwnPropertySymbols()

Devuelve un objeto que contiene todas las propiedades símbolo encontradas directamente en un objeto dado.

Object.getPrototypeOf()

Devuelve el prototipo (la propiedad interna [[Prototype]]) del objeto especificado.

Object.is()

Compara si dos valores son el mismo valor. Iguala todos los valores NaN (lo que difiere de la Comparación Abstracta de Igualdad y de la Comparación Estricta de Igualdad).

Object.isExtensible()

Determina si está permitido extender un objeto.

Object.isFrozen()

Determina si un objeto está congelado.

Object.isSealed()

Determines si un objeto está sellado.

Object.keys()

Devuelve un arreglo que contiene todos los nombres de las propiedades enumerables de tipo cadena de texto pertenecientes al objeto dado.

Object.preventExtensions()

Previene que un objeto pueda extenderse.

Object.seal()

Previene que otro código pueda borrar propiedades de un objeto.

Object.setPrototypeOf()

Estipula el prototipo de un objeto (su propiedad interna [[Prototype]]).

Object.values()

Devuelve un arreglo que contiene todos los valores correspondientes a las propiedades enumerables de tipo cadena de texto pertenecientes a un objeto dado.

Propiedades de instancia

Object.prototype.constructor

Especifica la función que crea el prototipo de un objeto.

Object.prototype.__proto__

Apunta al objeto que fue usado como prototipo cuando el objeto fue instanciado.

Métodos de instancia

Object.prototype.__defineGetter__()

Asocia una función a una propiedad que, cuando es accedida, ejecuta la función y retorna su valor de retorno.

Object.prototype.__defineSetter__()

Asocia una función a una propiedad que, cuando es estipulada, ejecuta la función que modificará dicha propiedad.

Object.prototype.__lookupGetter__()

Devuelve la función asociada a la propiedad establecida por el método Object.prototype.__defineGetter__().

Object.prototype.__lookupSetter__()

Devuelve la función asociada a la propiedad establecida por el método Object.prototype.__defineSetter__().

Object.prototype.hasOwnProperty()

Devuelve un booleano que indica si el objeto contiene una propiedad determinada como una propiedad directa del objeto y que no haya sido heredada a través de la cadena de prototipos.

Object.prototype.isPrototypeOf()

Devuelve un booleano que indica si el objeto por el cual este método está siendo llamado está en la cadena de prototipos del objeto específicado.

Object.prototype.propertyIsEnumerable()

Devuelve un booleano indicando si el [atributo ECMAScript [Enumerable]] interno está establecido.

Object.prototype.toLocaleString()

Llama a toString().

Object.prototype.toString()

Devuelve una representación del objeto en formato cadena de texto.

Object.prototype.valueOf()

Devuelve el valor primitivo del objeto especificado.

Ejemplos

Usando Object dados los tipos undefined y null

Los siguientes ejemplos almacenan un objeto vacío Object en o:

js
let o = new Object();
js
let o = new Object(undefined);
js
let o = new Object(null);

Usando Object para crear objetos Boolean

Los siguientes ejemplos almacenan objetos Boolean en o:

js
// equivalente a o = new Boolean(true)
let o = new Object(true);
js
// equivalente a o = new Boolean(false)
let o = new Object(Boolean());

Prototipos del objeto

Cuando altere el comportamiento de los métodos existentes en Object.prototype, considere inyectar el código envolviendo la extensión antes o después de la lógica existente. Por ejemplo, este código (no testeado) ejecutará precondicionalmente la lógica modificada antes que la lógica predefinida o la ejecución de cualquier otra extensión.

Cuando una función es llamada, los argumentos de la llamada son retenidos por la "variable" pseudo-arreglo arguments. Por ejemplo en la llamada myFn(a, b, c), los argumentos dentro del cuerpo de myFn contendrán tres elementos pseudo-arreglo correspondientes a (a, b, c).

Cuando modificamos prototipos con hooks, pase this y sus argumentos (el estado durante el llamado) al actual comportamiento llamando a apply() en la función. Esta patrón puede ser usado por cualquier prototipo, como Node.prototype, Function.prototype, etc.

js
var current = Object.prototype.valueOf;

// Ya que mi propiedad "-prop-value" es transversal y no siempre está
// en la misma cadena protipal, yo quiero cambiar el Object.prototype:
Object.prototype.valueOf = function () {
  if (this.hasOwnProperty("-prop-value")) {
    return this["-prop-value"];
  } else {
    // Si no parece uno de mis objetos, debo caer en
    // el comportamiento predeterminado reproduciendo el comportamiento actual lo mejor que podamos.
    // Apply se comporta como lo hace "super" en otros lenguajes.
    // A pesar de que valueOf() no tome ningún argumento, puede hacerlo.
    return current.apply(this, arguments);
  }
};

Ya que JavaScript no tiene exactamente objetos sub-clase, el prototipo sirve para crear objetos que actúen como "clase base" para ciertas funciones que actúan como objetos y así mitigar esta limitación. Por ejemplo:

js
var Person = function (name) {
  this.name = name;
  this.canTalk = true;
};

Person.prototype.greet = function () {
  if (this.canTalk) {
    console.log("Hola, yo soy " + this.name);
  }
};

var Employee = function (name, title) {
  Person.call(this, name);
  this.title = title;
};

Employee.prototype = Object.create(Person.prototype);
Employee.prototype.constructor = Employee;
//Si no aplicas Object.prototype.constructor a Employee,
//tomará prototype.constructor de Person (padre).
//Para evitarlo, aplicamos prototype.constructor a Employee (hijo).

Employee.prototype.greet = function () {
  if (this.canTalk) {
    console.log("Hola, yo soy " + this.name + ", el " + this.title);
  }
};

var Customer = function (name) {
  Person.call(this, name);
};

Customer.prototype = Object.create(Person.prototype);
Customer.prototype.constructor = Customer;
//Si no aplicas Object.prototype.constructor a Customer,
//tomará prototype.constructor de Person (padre).
//Para evitarlo, aplicamos prototype.constructor a Customer (hijo).

var Mime = function (name) {
  Person.call(this, name);
  this.canTalk = false;
};

Mime.prototype = Object.create(Person.prototype);
Mime.prototype.constructor = Mime;
//Si no aplicas Object.prototype.constructor a Mime,
//tomará prototype.constructor de Person (padre).
//Para evitarlo, aplicamos prototype.constructor a Mime (hijo).

var bob = new Employee("Bob", "Constructor");
var joe = new Customer("Joe");
var rg = new Employee("Red Green", "Reparador");
var mike = new Customer("Mike");
var mime = new Mime("Mime");

bob.greet();
// Hola, yo soy Bob, el Constructor

joe.greet();
// Hola, yo soy Joe

rg.greet();
// Hola, yo soy Red Green, el Reparador

mike.greet();
// Hola, yo soy Mike

mime.greet();

Especificaciones

Specification
ECMAScript Language Specification
# sec-object-objects

Compatibilidad con navegadores

BCD tables only load in the browser

Véase también