- Notifications
You must be signed in to change notification settings - Fork230
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 ourterms of service andprivacy statement. We’ll occasionally send you account related emails.
Already on GitHub?Sign in to your account
Merged
joaquinelio merged 14 commits intojavascript-tutorial:masterfromrainvare:rainvare-patch-1Jun 30, 2020
Uh oh!
There was an error while loading.Please reload this page.
Merged
Changes fromall commits
Commits
Show all changes
14 commits Select commitHold shift + click to select a range
84d9a86
Update article.md
rainvare62996fc
Merge branch 'master' into rainvare-patch-1
joaquinelio05a92e5
Update article.md
rainvaref9b2439
Update article.md
rainvare78810a6
Update 1-js/07-object-properties/02-property-accessors/article.md
rainvare1ddc056
Update 1-js/07-object-properties/02-property-accessors/article.md
rainvaree9b0519
Update 1-js/07-object-properties/02-property-accessors/article.md
rainvare0988760
Update 1-js/07-object-properties/02-property-accessors/article.md
rainvare3cee180
Update 1-js/07-object-properties/02-property-accessors/article.md
rainvarec19bdf8
Update 1-js/07-object-properties/02-property-accessors/article.md
rainvare67303a9
Update 1-js/07-object-properties/02-property-accessors/article.md
rainvare0cb05bb
Update article.md
rainvarefc70112
Update 1-js/07-object-properties/02-property-accessors/article.md
joaquinelio039e27b
Update 1-js/07-object-properties/02-property-accessors/article.md
joaquinelioFile filter
Filter by extension
Conversations
Failed to load comments.
Loading
Uh oh!
There was an error while loading.Please reload this page.
Jump to
Jump to file
Failed to load files.
Loading
Uh oh!
There was an error while loading.Please reload this page.
Diff view
Diff view
There are no files selected for viewing
85 changes: 43 additions & 42 deletions1-js/07-object-properties/02-property-accessors/article.md
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 | ||||
---|---|---|---|---|---|---|
@@ -1,31 +1,31 @@ | ||||||
# Property getters and setters | ||||||
Hay dos tipos de propiedades de objetos. | ||||||
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 acceso*.Estas son esencialmente funciones que se ejecutan para la obtención y asignación de un valor, pero parecen propiedades normales para un código externo. | ||||||
## Getters and setters | ||||||
Las propiedades de acceso están representadas por métodos"getter"y "setter". Propiamente, en un objeto se denotan por`get`y `set`: | ||||||
```js | ||||||
let obj = { | ||||||
*!*get propName()*/!* { | ||||||
// getter,el código ejecutado para obtener obj.propName | ||||||
}, | ||||||
*!*set propName(value)*/!* { | ||||||
// setter,el código ejecutado para asignar obj.propName = value | ||||||
} | ||||||
}; | ||||||
``` | ||||||
El getterfunciona cuando se lee`obj.propName`, el setter --cuando se asigna. | ||||||
joaquinelio marked this conversation as resolved. Show resolvedHide resolvedUh oh!There was an error while loading.Please reload this page. | ||||||
Por ejemplo, tenemos un objeto "usuario" con "nombre" y "apellido": | ||||||
```js | ||||||
let user = { | ||||||
@@ -34,7 +34,7 @@ let user = { | ||||||
}; | ||||||
``` | ||||||
Ahora queremos añadir una propiedad de "Nombre completo" (`fullName`), que debería ser `"John Smith"`.Por supuesto, no queremos copiar-pegar la información existente, así que podemos aplicarla como una propiedad de acceso: | ||||||
```js run | ||||||
let user = { | ||||||
@@ -53,9 +53,9 @@ alert(user.fullName); // John Smith | ||||||
*/!* | ||||||
``` | ||||||
Desde fuera, una propiedad de acceso se parece a una normal. Esa es laideade estas propiedades. No *llamamos* a`user.fullName`como una función, la *leemos* normalmente: el "getter" corre detrás de la escena. | ||||||
A partir de ahora, "Nombre completo" sólo tiene un receptor. Si intentamos asignar`user.fullName=`,habrá unerror. | ||||||
```js run | ||||||
let user = { | ||||||
@@ -69,7 +69,7 @@ user.fullName = "Test"; // Error (property has only a getter) | ||||||
*/!* | ||||||
``` | ||||||
Arreglémoslo agregando unsetterpara `user.fullName`: | ||||||
```js run | ||||||
let user = { | ||||||
@@ -87,29 +87,30 @@ let user = { | ||||||
*/!* | ||||||
}; | ||||||
// set fullNamese ejecuta con el valor dado. | ||||||
user.fullName = "Alice Cooper"; | ||||||
alert(user.name); // Alice | ||||||
alert(user.surname); // Cooper | ||||||
``` | ||||||
Como resultado, tenemos una propiedad virtual `fullName` que puede leerse y escribirse. | ||||||
## Accessor descriptors | ||||||
Los descriptores de las propiedades de acceso son diferentes de aquellos para las propiedades de los datos. | ||||||
Para las propiedades de acceso, nohay cosas como "valor" y "escritura", sino de "get" y "set". | ||||||
Así que undescriptorde 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 acceso " Nombre Completo" con "Definir Propiedad", podemos pasar undescriptorcon `get`y `set`: | ||||||
Contributor
|
Por ejemplo, para crear un acceso" Nombre Completo"con"Definir Propiedad", podemos pasar un descriptor con`get` y`set`: | |
Por ejemplo, para crear un acceso`fullName`con`defineProperty`, podemos pasar un descriptor con`get` y`set`: |
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.