aboutsummaryrefslogtreecommitdiff
path: root/files/es/web/javascript/enumeracion_y_propietario_de_propiedades/index.html
diff options
context:
space:
mode:
Diffstat (limited to 'files/es/web/javascript/enumeracion_y_propietario_de_propiedades/index.html')
-rw-r--r--files/es/web/javascript/enumeracion_y_propietario_de_propiedades/index.html333
1 files changed, 0 insertions, 333 deletions
diff --git a/files/es/web/javascript/enumeracion_y_propietario_de_propiedades/index.html b/files/es/web/javascript/enumeracion_y_propietario_de_propiedades/index.html
deleted file mode 100644
index fbe97185f6..0000000000
--- a/files/es/web/javascript/enumeracion_y_propietario_de_propiedades/index.html
+++ /dev/null
@@ -1,333 +0,0 @@
----
-title: Enumerabilidad y posesión de propiedades
-slug: Web/JavaScript/enumeracion_y_propietario_de_propiedades
-tags:
- - Enumerabilidad
- - Enumeración
- - Guía
- - JavaScript
- - Propiedades
-translation_of: Web/JavaScript/Enumerability_and_ownership_of_properties
----
-<div>{{JsSidebar("Más")}}</div>
-
-<p>Las propiedades enumerables son aquellas propiedades cuyo indicador enumerable interno se establece en <code>true</code>, que es el valor predeterminado para las propiedades creadas mediante una asignación simple o mediante un iniciador de propiedad (propiedades definidas mediante {{jsxref("Global_Objects/Object/defineProperty", "Object.defineProperty")}} y tal valor enumerable predeterminado a <code>false</code>). Se muestran numerosas propiedades en bucles {{jsref("Statements/for...in", "for...in")}} a menos que la clave de la propiedad sea {{jsxref("Global_Objects/Symbol", "Symbol")}}. La posesión de las propiedades está determinada por si la propiedad pertenece directamente al objeto y no a su cadena prototipo. Las propiedades de un objeto también se pueden recuperar en total. Hay varios medios incorporados para detectar, iterar/enumerar y recuperar propiedades de objetos, y el gráfico que se muestra a continuación está disponible. A continuación, se muestra un código de muestra que demuestra cómo obtener las categorías faltantes.</p>
-
-<div style="overflow: auto; width: 100%;">
-<table>
- <caption>Propiedad, enumerabilidad y posesión — métodos integrados de detección, recuperación e iteración</caption>
- <tbody>
- <tr>
- <th>Funcionalidad</th>
- <th>Propia del Objeto</th>
- <th>Propia del Objeto y su cadena prototipo</th>
- <th>Solo en cadena prototipo</th>
- </tr>
- <tr>
- <td>Detección</td>
- <td>
- <table>
- <thead>
- <tr>
- <th scope="col">Enumerable</th>
- <th scope="col">No enumerable</th>
- <th scope="col">Enumerable y no enumerable</th>
- </tr>
- </thead>
- <tbody>
- <tr>
- <td>
- <p>{{jsxref("Global_Objects/Object/propertyIsEnumerable", "propertyIsEnumerable")}}</p>
-
- <p>{{jsxref("Global_Objects/Object/hasOwnProperty", "hasOwnProperty")}}</p>
- </td>
- <td>
- <p>{{jsxref("Global_Objects/Object/hasOwnProperty", "hasOwnProperty")}} — filtrado para excluir enumerables mediante {{jsxref("Global_Objects/Object/propertyIsEnumerable", "propertyIsEnumerable")}}</p>
- </td>
- <td>{{jsxref("Global_Objects/Object/hasOwnProperty", "hasOwnProperty")}}</td>
- </tr>
- </tbody>
- </table>
- </td>
- <td>
- <table>
- <thead>
- <tr>
- <th scope="col">Enumerable</th>
- <th scope="col">No enumerable</th>
- <th scope="col">Enumerable y no enumerable</th>
- </tr>
- </thead>
- <tbody>
- <tr>
- <td>No disponible sin código adicional</td>
- <td>No disponible sin código adicional</td>
- <td>{{jsxref("Operators/in", "in")}}</td>
- </tr>
- </tbody>
- </table>
- </td>
- <td>No disponible sin código adicional</td>
- </tr>
- <tr>
- <td>Recuperación</td>
- <td>
- <table>
- <thead>
- <tr>
- <th scope="col">Enumerable</th>
- <th scope="col">No enumerable</th>
- <th scope="col">Enumerable y no enumerable</th>
- </tr>
- </thead>
- <tbody>
- <tr>
- <td>
- <p>{{jsxref("Global_Objects/Object/keys", "Object.keys")}}</p>
-
- <p>{{jsxref("Global_Objects/Object/getOwnPropertyNames", "getOwnPropertyNames")}}</p>
-
- <p>{{jsxref("Global_Objects/Object/getOwnPropertySymbols", "getOwnPropertySymbols")}}</p>
- </td>
- <td>{{jsxref("Global_Objects/Object/getOwnPropertyNames", "getOwnPropertyNames")}}, {{jsxref("Global_Objects/Object/getOwnPropertySymbols", "getOwnPropertySymbols")}} — filtrado para excluir enumerables usando {{jsxref("Global_Objects/Object/propertyIsEnumerable", "propertyIsEnumerable")}}</td>
- <td>
- <p>{{jsxref("Global_Objects/Object/getOwnPropertyNames", "getOwnPropertyNames")}}</p>
-
- <p>{{jsxref("Global_Objects/Object/getOwnPropertySymbols", "getOwnPropertySymbols")}}</p>
- </td>
- </tr>
- </tbody>
- </table>
- </td>
- <td>No disponible sin código adicional</td>
- <td>No disponible sin código adicional</td>
- </tr>
- <tr>
- <td>Iterable</td>
- <td>
- <table>
- <thead>
- <tr>
- <th scope="col">Enumerable</th>
- <th scope="col">No enumerable</th>
- <th scope="col">Enumerable y no enumerable</th>
- </tr>
- </thead>
- <tbody>
- <tr>
- <td>
- <p>{{jsxref("Global_Objects/Object/keys", "Object.keys")}}</p>
-
- <p>{{jsxref("Global_Objects/Object/getOwnPropertyNames", "getOwnPropertyNames")}}</p>
-
- <p>{{jsxref("Global_Objects/Object/getOwnPropertySymbols", "getOwnPropertySymbols")}}</p>
- </td>
- <td>{{jsxref("Global_Objects/Object/getOwnPropertyNames", "getOwnPropertyNames")}}, {{jsxref("Global_Objects/Object/getOwnPropertySymbols", "getOwnPropertySymbols")}} — filtrado para excluir enumerables usando {{jsxref("Global_Objects/Object/propertyIsEnumerable", "propertyIsEnumerable")}}</td>
- <td>
- <p>{{jsxref("Global_Objects/Object/getOwnPropertyNames", "getOwnPropertyNames")}}</p>
-
- <p>{{jsxref("Global_Objects/Object/getOwnPropertySymbols", "getOwnPropertySymbols")}}</p>
- </td>
- </tr>
- </tbody>
- </table>
- </td>
- <td>
- <table>
- <thead>
- <tr>
- <th scope="col">Enumerable</th>
- <th scope="col">No enumerable</th>
- <th scope="col">Enumerable y no enumerable</th>
- </tr>
- </thead>
- <tbody>
- <tr>
- <td>
- <p>{{jsxref("Statements/for...in", "for..in")}}</p>
-
- <p>(no incluye símbolos)</p>
- </td>
- <td>No disponible sin código adicional</td>
- <td>No disponible sin código adicional</td>
- </tr>
- </tbody>
- </table>
- </td>
- <td>No disponible sin código adicional</td>
- </tr>
- </tbody>
-</table>
-</div>
-
-<h2 id="Obtención_de_propiedades_por_enumerabilidadposesión">Obtención de propiedades por enumerabilidad/posesión</h2>
-
-<p>Ten en cuenta que este no es el algoritmo más eficiente para todos los casos, pero es útil para una demostración rápida.</p>
-
-<ul>
- <li>La detección puede ocurrir por <code>SimplePropertyRetriever.theGetMethodYouWant(obj).indexOf(prop) &gt; -1</code></li>
- <li>La iteración puede ocurrir por <code>SimplePropertyRetriever.theGetMethodYouWant(obj).forEach(function (value, prop) {});</code> (o usa <code>filter()</code>, <code>map()</code>, etc.)</li>
-</ul>
-
-<pre class="brush: js notranslate">var SimplePropertyRetriever = {
- getOwnEnumerables: function(obj) {
- return this._getPropertyNames(obj, true, false, this._enumerable);
- // O podrías usar for..in filtrado con hasOwnProperty o simplemente esto: return Object.keys(obj);
- },
- getOwnNonenumerables: function(obj) {
- return this._getPropertyNames(obj, true, false, this._notEnumerable);
- },
- getOwnEnumerablesAndNonenumerables: function(obj) {
- return this._getPropertyNames(obj, true, false, this._enumerableAndNotEnumerable);
- // O simplemente usa: return Object.getOwnPropertyNames(obj);
- },
- getPrototypeEnumerables: function(obj) {
- return this._getPropertyNames(obj, false, true, this._enumerable);
- },
- getPrototypeNonenumerables: function(obj) {
- return this._getPropertyNames(obj, false, true, this._notEnumerable);
- },
- getPrototypeEnumerablesAndNonenumerables: function(obj) {
- return this._getPropertyNames(obj, false, true, this._enumerableAndNotEnumerable);
- },
- getOwnAndPrototypeEnumerables: function(obj) {
- return this._getPropertyNames(obj, true, true, this._enumerable);
- // O podrías usar "for..in" sin filtrar
- },
- getOwnAndPrototypeNonenumerables: function(obj) {
- return this._getPropertyNames(obj, true, true, this._notEnumerable);
- },
- getOwnAndPrototypeEnumerablesAndNonenumerables: function(obj) {
- return this._getPropertyNames(obj, true, true, this._enumerableAndNotEnumerable);
- },
- // Retrollamada del supervisor de propiedad estática privada
- _enumerable: function(obj, prop) {
- return obj.propertyIsEnumerable(prop);
- },
- _notEnumerable: function(obj, prop) {
- return !obj.propertyIsEnumerable(prop);
- },
- _enumerableAndNotEnumerable: function(obj, prop) {
- return true;
- },
- // Inspirado en http://stackoverflow.com/a/8024294/271577
- _getPropertyNames: function getAllPropertyNames(obj, iterateSelfBool, iteratePrototypeBool, includePropCb) {
- var props = [];
-
- do {
- if (iterateSelfBool) {
- Object.getOwnPropertyNames(obj).forEach(function(prop) {
- if (props.indexOf(prop) === -1 &amp;&amp; includePropCb(obj, prop)) {
- props.push(prop);
- }
- });
- }
- if (!iteratePrototypeBool) {
- break;
- }
- iterateSelfBool = true;
- } while (obj = Object.getPrototypeOf(obj));
-
- return props;
- }
-};</pre>
-
-<h2 id="Tabla_de_detección">Tabla de detección</h2>
-
-<div style="overflow: auto; width: 100%;">
-<table>
- <thead>
- <tr>
- <th scope="row"></th>
- <th scope="col"><code>in</code></th>
- <th scope="col"><code>for..in</code></th>
- <th scope="col"><code>obj.hasOwnProperty</code></th>
- <th scope="col"><code>obj.propertyIsEnumerable</code></th>
- <th scope="col"><code>Object.keys</code></th>
- <th scope="col"><code>Object.getOwnPropertyNames</code></th>
- <th scope="col"><code>Object.getOwnPropertyDescriptors</code></th>
- <th scope="col"><code>Reflect.ownKeys()</code></th>
- </tr>
- </thead>
- <tbody>
- <tr>
- <th scope="row">Enumerable</th>
- <td>true</td>
- <td>true</td>
- <td>true</td>
- <td>true</td>
- <td>true</td>
- <td>true</td>
- <td>true</td>
- <td>true</td>
- </tr>
- <tr>
- <th scope="row">No enumerable</th>
- <td>true</td>
- <td>false</td>
- <td>true</td>
- <td>false</td>
- <td>false</td>
- <td>true</td>
- <td>true</td>
- <td>true</td>
- </tr>
- <tr>
- <th scope="row">Símbolos clave</th>
- <td>true</td>
- <td>false</td>
- <td>true</td>
- <td>true</td>
- <td>false</td>
- <td>false</td>
- <td>true</td>
- <td>true</td>
- </tr>
- <tr>
- <th scope="row">Enumerable heredado</th>
- <td>true</td>
- <td>true</td>
- <td>false</td>
- <td>false</td>
- <td>false</td>
- <td>false</td>
- <td>false</td>
- <td>false</td>
- </tr>
- <tr>
- <th scope="row">Heredado no enumerable</th>
- <td>true</td>
- <td>false</td>
- <td>false</td>
- <td>false</td>
- <td>false</td>
- <td>false</td>
- <td>false</td>
- <td>false</td>
- </tr>
- <tr>
- <th scope="row">Símbolos clave heredados</th>
- <td>true</td>
- <td>false</td>
- <td>false</td>
- <td>false</td>
- <td>false</td>
- <td>false</td>
- <td>false</td>
- <td>false</td>
- </tr>
- </tbody>
-</table>
-</div>
-
-<h2 id="Ve_también">Ve también</h2>
-
-<ul>
- <li>{{jsxref("Operators/in", "in")}}</li>
- <li>{{jsxref("Statements/for...in", "for..in")}}</li>
- <li>{{jsxref("Object.hasOwnProperty()")}}</li>
- <li>{{jsxref("Object.propertyIsEnumerable()")}}</li>
- <li>{{jsxref("Object.getOwnPropertyNames()")}}</li>
- <li>{{jsxref("Object.keys()")}}</li>
- <li>{{jsxref("Object.getOwnPropertyDescriptors()")}}</li>
-</ul>