-
Notifications
You must be signed in to change notification settings - Fork 229
Property getters and setters #194
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Merged
joaquinelio
merged 14 commits into
javascript-tutorial:master
from
rainvare:rainvare-patch-1
Jun 30, 2020
Merged
Changes from 1 commit
Commits
Show all changes
14 commits
Select commit
Hold shift + click to select a range
84d9a86
Update article.md
rainvare 62996fc
Merge branch 'master' into rainvare-patch-1
joaquinelio 05a92e5
Update article.md
rainvare f9b2439
Update article.md
rainvare 78810a6
Update 1-js/07-object-properties/02-property-accessors/article.md
rainvare 1ddc056
Update 1-js/07-object-properties/02-property-accessors/article.md
rainvare e9b0519
Update 1-js/07-object-properties/02-property-accessors/article.md
rainvare 0988760
Update 1-js/07-object-properties/02-property-accessors/article.md
rainvare 3cee180
Update 1-js/07-object-properties/02-property-accessors/article.md
rainvare c19bdf8
Update 1-js/07-object-properties/02-property-accessors/article.md
rainvare 67303a9
Update 1-js/07-object-properties/02-property-accessors/article.md
rainvare 0cb05bb
Update article.md
rainvare fc70112
Update 1-js/07-object-properties/02-property-accessors/article.md
joaquinelio 039e27b
Update 1-js/07-object-properties/02-property-accessors/article.md
joaquinelio File filter
Filter by extension
Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
There are no files selected for viewing
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
| Original file line number | Diff line number | Diff line change | ||||
|---|---|---|---|---|---|---|
|
|
@@ -5,20 +5,20 @@ Hay dos tipos de propiedades. | |||||
|
|
||||||
| El primer tipo son las *propiedades de los datos*. Ya sabemos cómo trabajar con ellas. En realidad, todas las propiedades que hemos estado usando hasta ahora eran propiedades de datos. | ||||||
|
|
||||||
| El segundo tipo de propiedades es algo nuevo. Son las *propiedades de los accesorios*. Estas son esencialmente funciones que trabajan en la obtención y configuración de un valor, pero que parecen propiedades normales de un código externo. | ||||||
| El segundo tipo de propiedades es algo nuevo. Son las *propiedades de acceso*. Estas son esencialmente funciones que, trabajan en la obtención y asignación de un valor, pero parecen propiedades normales para un código externo. | ||||||
|
|
||||||
| ## Getters and setters | ||||||
|
|
||||||
| Las propiedades del accesorio están representadas por los métodos "getter" y "setter". En un objeto con la notación literal se denotan por "get" y "set": | ||||||
| Las propiedades de acceso están representadas por los métodos "getter" y "setter". En un objeto con la notación literal se denotan por "get" y "set": | ||||||
|
Member
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more.
Suggested change
|
||||||
|
|
||||||
| ```js | ||||||
| let obj = { | ||||||
| *!*get propName()*/!* { | ||||||
| // getter, el código ejecutado al obtener obj.propName | ||||||
| // getter, el código ejecutado para asignar obj.propName | ||||||
|
rainvare marked this conversation as resolved.
Outdated
|
||||||
| }, | ||||||
|
|
||||||
| *!*set propName(value)*/!* { | ||||||
| // setter, el código ejecutado al obtener obj.propName = value | ||||||
| // setter, el código ejecutado para asignar obj.propName = value | ||||||
| } | ||||||
| }; | ||||||
| ``` | ||||||
|
|
@@ -34,7 +34,7 @@ let user = { | |||||
| }; | ||||||
| ``` | ||||||
|
|
||||||
| Ahora queremos añadir una propiedad de "nombre completo", que debería ser "John Smith". Por supuesto, no queremos copiar-pegar la información existente, así que podemos aplicarla como un accesorio: | ||||||
| Ahora queremos añadir una propiedad de "nombre completo", que debería ser "John Smith". Por supuesto, no queremos copiar-pegar la información existente, así que podemos aplicarla como un acceso: | ||||||
|
Member
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more.
Suggested change
|
||||||
|
|
||||||
| ```js run | ||||||
| let user = { | ||||||
|
|
@@ -53,7 +53,7 @@ alert(user.fullName); // John Smith | |||||
| */!* | ||||||
| ``` | ||||||
|
|
||||||
| Desde fuera, una propiedad accesoria se parece a una normal. Esa es la idea de las propiedades accesorias. No llamamos a " user.fullName" como una función, la leemos normalmente: el "getter" corre detrás de la escena. | ||||||
| Desde fuera, una propiedad de acceso se parece a una normal. Esa es la idea de estas propiedades. No llamamos a " user.fullName" como una función, la leemos normalmente: el "getter" corre detrás de la escena. | ||||||
|
rainvare marked this conversation as resolved.
Outdated
|
||||||
|
|
||||||
| A partir de ahora, "Nombre completo" sólo tiene un receptor. Si intentamos asignar "user.fullName", habrá un error. | ||||||
|
joaquinelio marked this conversation as resolved.
Outdated
|
||||||
|
|
||||||
|
|
@@ -111,16 +111,16 @@ Como resultado, tenemos una propiedad virtual `fullName` que puede leerse y escr | |||||
|
|
||||||
| Los descriptores de las propiedades de acceso son diferentes de aquellos para las propiedades de los datos. | ||||||
|
|
||||||
| Para las propiedades de los accesorios, no hay cosas como "valor" y "escritura", sino de "get" y "set". | ||||||
| Para las propiedades de acceso, no hay cosas como "valor" y "escritura", sino de "get" y "set". | ||||||
|
|
||||||
| Así que un descriptor de accesorios puede tener: | ||||||
| Así que un descriptor de accesos puede tener: | ||||||
|
|
||||||
| - **`get`** -- una función sin argumentos, que funciona cuando se lee una propiedad, | ||||||
| - **`set`** -- una función con un argumento, que se llama cuando se establece la propiedad, | ||||||
| - **`enumerable`** -- lo mismo que para las propiedades de los datos, | ||||||
| - **`configurable`** -- lo mismo que para las propiedades de los datos. | ||||||
|
|
||||||
| Por ejemplo, para crear un accesorio " Nombre Completo" con "Definir Propiedad", podemos pasar un descriptor con `get` y `set`: | ||||||
| Por ejemplo, para crear un acceso " Nombre Completo" con "Definir Propiedad", podemos pasar un descriptor con `get` y `set`: | ||||||
|
Contributor
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more.
Suggested change
|
||||||
|
|
||||||
| ```js run | ||||||
| let user = { | ||||||
|
|
@@ -145,7 +145,7 @@ alert(user.fullName); // John Smith | |||||
| for(let key in user) alert(key); // name, surname | ||||||
| ``` | ||||||
|
|
||||||
| Tenga en cuenta que una propiedad puede ser un accesorio (tiene métodos `get/set`) o una propiedad de datos (tiene un 'valor'), no ambas. | ||||||
| Tenga en cuenta que una propiedad puede ser un acceso (tiene métodos `get/set`) o una propiedad de datos (tiene un 'valor'), no ambas. | ||||||
|
|
||||||
| Si intentamos poner tanto " get" como " valor" en el mismo descriptor, habrá un error: | ||||||
|
rainvare marked this conversation as resolved.
Outdated
|
||||||
|
|
||||||
|
|
||||||
Add this suggestion to a batch that can be applied as a single commit.
This suggestion is invalid because no changes were made to the code.
Suggestions cannot be applied while the pull request is closed.
Suggestions cannot be applied while viewing a subset of changes.
Only one suggestion per line can be applied in a batch.
Add this suggestion to a batch that can be applied as a single commit.
Applying suggestions on deleted lines is not supported.
You must change the existing code in this line in order to create a valid suggestion.
Outdated suggestions cannot be applied.
This suggestion has been applied or marked resolved.
Suggestions cannot be applied from pending reviews.
Suggestions cannot be applied on multi-line comments.
Suggestions cannot be applied while the pull request is queued to merge.
Suggestion cannot be applied right now. Please check back later.
Uh oh!
There was an error while loading. Please reload this page.