<?xml version="1.0" encoding="UTF-8"?>
<rss version="2.0" xmlns:atom="http://www.w3.org/2005/Atom" xmlns:dc="http://purl.org/dc/elements/1.1/">
  <channel>
    <title>DEV Community: gera</title>
    <description>The latest articles on DEV Community by gera (@gerardosabetta).</description>
    <link>https://dev.to/gerardosabetta</link>
    <image>
      <url>https://media2.dev.to/dynamic/image/width=90,height=90,fit=cover,gravity=auto,format=auto/https:%2F%2Fdev-to-uploads.s3.amazonaws.com%2Fuploads%2Fuser%2Fprofile_image%2F355008%2F1ac521ba-c361-422a-9320-144bbb406b5a.png</url>
      <title>DEV Community: gera</title>
      <link>https://dev.to/gerardosabetta</link>
    </image>
    <atom:link rel="self" type="application/rss+xml" href="https://dev.to/feed/gerardosabetta"/>
    <language>en</language>
    <item>
      <title>Introducción a objetos en javascript</title>
      <dc:creator>gera</dc:creator>
      <pubDate>Sat, 01 Aug 2020 17:16:18 +0000</pubDate>
      <link>https://dev.to/gerardosabetta/introduccion-a-objetos-en-javascript-37e3</link>
      <guid>https://dev.to/gerardosabetta/introduccion-a-objetos-en-javascript-37e3</guid>
      <description>&lt;p&gt;&lt;a href="https://res.cloudinary.com/practicaldev/image/fetch/s--bylvbdY7--/c_limit%2Cf_auto%2Cfl_progressive%2Cq_auto%2Cw_800/https://dev-to-uploads.s3.amazonaws.com/i/1hd7rlghprhokltgk6x4.png" class="article-body-image-wrapper"&gt;&lt;img src="https://res.cloudinary.com/practicaldev/image/fetch/s--bylvbdY7--/c_limit%2Cf_auto%2Cfl_progressive%2Cq_auto%2Cw_800/https://dev-to-uploads.s3.amazonaws.com/i/1hd7rlghprhokltgk6x4.png" alt="A mind map image" width="800" height="517"&gt;&lt;/a&gt;&lt;br&gt;
Veamos de que se trata este concepto del que tanto escuchamos hablar en programación.&lt;/p&gt;

&lt;p&gt;Comenzando con una definición básica pero técnica un objeto es un tipo de dato compuesto por un conjunto de claves y valores. No dejes que la definición te abrume, es sencillo! veamos un ejemplo.&lt;br&gt;
&lt;/p&gt;

&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight jsx"&gt;&lt;code&gt;&lt;span class="kd"&gt;let&lt;/span&gt; &lt;span class="nx"&gt;persona&lt;/span&gt; &lt;span class="o"&gt;=&lt;/span&gt; &lt;span class="p"&gt;{&lt;/span&gt;
   &lt;span class="na"&gt;nombre&lt;/span&gt;&lt;span class="p"&gt;:&lt;/span&gt; &lt;span class="dl"&gt;'&lt;/span&gt;&lt;span class="s1"&gt;John Doe&lt;/span&gt;&lt;span class="dl"&gt;'&lt;/span&gt;
   &lt;span class="na"&gt;edad&lt;/span&gt;&lt;span class="p"&gt;:&lt;/span&gt; &lt;span class="mi"&gt;34&lt;/span&gt;
&lt;span class="p"&gt;}&lt;/span&gt;
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;p&gt;Ya viste tu primer objeto, y estoy seguro de que entendiste de que se trata. Estamos declarando una variable y su valor es un objeto, un objeto que tiene nombre y edad. Estas características de nuestro objeto (nombre y edad en este caso) son conocidas como propiedades y como lo habrás notado cada propiedad es un par de &lt;code&gt;clave:valor&lt;/code&gt;. Por clave comprendemos el nombre de la propiedad y lo que representa, mientras que por valor, obviamente, el valor de esta propiedad.&lt;/p&gt;

&lt;p&gt;Una vez creado tu objeto podes acceder a sus propiedades de las siguientes maneras&lt;br&gt;
&lt;/p&gt;

&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight jsx"&gt;&lt;code&gt;&lt;span class="c1"&gt;// Notacion de punto: &lt;/span&gt;
&lt;span class="nx"&gt;persona&lt;/span&gt;&lt;span class="p"&gt;.&lt;/span&gt;&lt;span class="nx"&gt;nombre&lt;/span&gt;&lt;span class="p"&gt;;&lt;/span&gt; &lt;span class="c1"&gt;// =&amp;gt; John Doe&lt;/span&gt;

&lt;span class="c1"&gt;// Notacion de brackets []&lt;/span&gt;
&lt;span class="nx"&gt;persona&lt;/span&gt;&lt;span class="p"&gt;[&lt;/span&gt;&lt;span class="dl"&gt;"&lt;/span&gt;&lt;span class="s2"&gt;edad&lt;/span&gt;&lt;span class="dl"&gt;"&lt;/span&gt;&lt;span class="p"&gt;];&lt;/span&gt; &lt;span class="c1"&gt;// =&amp;gt; 34&lt;/span&gt;

&lt;span class="c1"&gt;// Modificar el nombre de la persona&lt;/span&gt;
&lt;span class="nx"&gt;persona&lt;/span&gt;&lt;span class="p"&gt;.&lt;/span&gt;&lt;span class="nx"&gt;nombre&lt;/span&gt; &lt;span class="o"&gt;=&lt;/span&gt; &lt;span class="dl"&gt;"&lt;/span&gt;&lt;span class="s2"&gt;Jane Doe&lt;/span&gt;&lt;span class="dl"&gt;"&lt;/span&gt;&lt;span class="p"&gt;;&lt;/span&gt;
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;p&gt;En ese ejemplo creamos un objeto literal, esto significa que declaramos nuestro objeto abriendo llaves &lt;code&gt;{}&lt;/code&gt; y volcando las propiedades que queremos guardar ahí dentro, en breve te voy a hablar de distintas formas de crear un objeto y te voy a contar lo que es una clase.&lt;/p&gt;

&lt;p&gt;Pero antes de continuar con lo que te acabo de mencionar en los párrafos anteriores ya deberías de poder ver el rol importante que juegan los objetos al momento de escribir nuestro código y que este este bien ordenado y se lea fácil, veamos como es esto.&lt;/p&gt;

&lt;p&gt;Si te pidiera que en tu programa almacenes datos de una persona sin utilizar objetos, probablemente lo harías de la siguiente manera.&lt;br&gt;
&lt;/p&gt;

&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight jsx"&gt;&lt;code&gt;&lt;span class="kd"&gt;let&lt;/span&gt; &lt;span class="nx"&gt;nombreDeLaPersona&lt;/span&gt; &lt;span class="o"&gt;=&lt;/span&gt; &lt;span class="dl"&gt;'&lt;/span&gt;&lt;span class="s1"&gt;John Doe&lt;/span&gt;&lt;span class="dl"&gt;'&lt;/span&gt;&lt;span class="p"&gt;;&lt;/span&gt;
&lt;span class="kd"&gt;let&lt;/span&gt; &lt;span class="nx"&gt;edadDeLaPersona&lt;/span&gt; &lt;span class="o"&gt;=&lt;/span&gt; &lt;span class="mi"&gt;34&lt;/span&gt;&lt;span class="p"&gt;;&lt;/span&gt;
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;p&gt;Y esto no esta del todo mal, es valido, el inconveniente que tenemos es que estamos declarando muchas variables que representan algo en común: los datos de una persona en particular. Además cada vez que te pida agregar un dato a tu programa, vas a terminar con unas cuantas variables sueltas desparramadas por tu programa! No es mejor crear un objeto donde sabemos que toda la información de esta persona va a estar contenida dentro?&lt;/p&gt;

&lt;p&gt;&lt;a href="https://res.cloudinary.com/practicaldev/image/fetch/s--IE5F7gG3--/c_limit%2Cf_auto%2Cfl_progressive%2Cq_auto%2Cw_800/https://dev-to-uploads.s3.amazonaws.com/i/harkrrnzytbcum3feb9g.png" class="article-body-image-wrapper"&gt;&lt;img src="https://res.cloudinary.com/practicaldev/image/fetch/s--IE5F7gG3--/c_limit%2Cf_auto%2Cfl_progressive%2Cq_auto%2Cw_800/https://dev-to-uploads.s3.amazonaws.com/i/harkrrnzytbcum3feb9g.png" alt="A girl leaning on folders" width="800" height="447"&gt;&lt;/a&gt;&lt;/p&gt;

&lt;p&gt;Imagínate tener todos tus apuntes del colegio en una sola carpeta, intentas darle un nombre descriptivo a cada archivo, como lo haces con tus variables en tu código, sin embargo, desaprovechas la oportunidad de ponerlos en carpetas y facilitarte la vida al momento de buscar tus archivos.&lt;/p&gt;

&lt;p&gt;&lt;a href="https://res.cloudinary.com/practicaldev/image/fetch/s--8YoR9iR4--/c_limit%2Cf_auto%2Cfl_progressive%2Cq_auto%2Cw_800/https://dev-to-uploads.s3.amazonaws.com/i/oyjshcktnez6z69p16ro.png" class="article-body-image-wrapper"&gt;&lt;img src="https://res.cloudinary.com/practicaldev/image/fetch/s--8YoR9iR4--/c_limit%2Cf_auto%2Cfl_progressive%2Cq_auto%2Cw_800/https://dev-to-uploads.s3.amazonaws.com/i/oyjshcktnez6z69p16ro.png" alt="A folder with many files" width="771" height="264"&gt;&lt;/a&gt;&lt;/p&gt;

&lt;p&gt;Ahora veamos como podes &lt;strong&gt;agrupar las cosas&lt;/strong&gt; un poco mejor...&lt;/p&gt;

&lt;p&gt;&lt;a href="https://res.cloudinary.com/practicaldev/image/fetch/s--xWqLz5zq--/c_limit%2Cf_auto%2Cfl_progressive%2Cq_auto%2Cw_800/https://dev-to-uploads.s3.amazonaws.com/i/dx59nkqkz4cjdqvvrzo3.png" class="article-body-image-wrapper"&gt;&lt;img src="https://res.cloudinary.com/practicaldev/image/fetch/s--xWqLz5zq--/c_limit%2Cf_auto%2Cfl_progressive%2Cq_auto%2Cw_800/https://dev-to-uploads.s3.amazonaws.com/i/dx59nkqkz4cjdqvvrzo3.png" alt="A folder with nested folders and organized files" width="771" height="264"&gt;&lt;/a&gt;&lt;/p&gt;

&lt;p&gt;Ya sabes que al momento de empezar a escribir tu código, si identificas que los datos que estas por meter en variables tienen algo en común, quizás sea sensato declararlos como propiedades de un objeto.&lt;/p&gt;

&lt;p&gt;Pero esto no termina acá, imagínate que necesito mas de una persona en mi programa, vas a escribir un objeto literal por cada una? Tienes una mejor alternativa. Podes empezar a crear objetos a partir de una clase!&lt;/p&gt;

&lt;p&gt;Una &lt;strong&gt;clase&lt;/strong&gt; es una plantilla para tus objetos, es una descripción de nuestros objetos, nos dice que propiedades y métodos van a tener nuestros objetos.&lt;br&gt;
&lt;/p&gt;

&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight jsx"&gt;&lt;code&gt;&lt;span class="kd"&gt;class&lt;/span&gt; &lt;span class="nx"&gt;Persona&lt;/span&gt; &lt;span class="p"&gt;{&lt;/span&gt;
  &lt;span class="kd"&gt;constructor&lt;/span&gt;&lt;span class="p"&gt;(&lt;/span&gt;&lt;span class="nx"&gt;nombre&lt;/span&gt;&lt;span class="p"&gt;,&lt;/span&gt; &lt;span class="nx"&gt;edad&lt;/span&gt;&lt;span class="p"&gt;)&lt;/span&gt; &lt;span class="p"&gt;{&lt;/span&gt;
    &lt;span class="k"&gt;this&lt;/span&gt;&lt;span class="p"&gt;.&lt;/span&gt;&lt;span class="nx"&gt;nombre&lt;/span&gt; &lt;span class="o"&gt;=&lt;/span&gt; &lt;span class="nx"&gt;nombre&lt;/span&gt;&lt;span class="p"&gt;;&lt;/span&gt;
    &lt;span class="k"&gt;this&lt;/span&gt;&lt;span class="p"&gt;.&lt;/span&gt;&lt;span class="nx"&gt;edad&lt;/span&gt; &lt;span class="o"&gt;=&lt;/span&gt; &lt;span class="nx"&gt;edad&lt;/span&gt;&lt;span class="p"&gt;;&lt;/span&gt;
  &lt;span class="p"&gt;}&lt;/span&gt;
&lt;span class="p"&gt;}&lt;/span&gt; 

&lt;span class="kd"&gt;let&lt;/span&gt; &lt;span class="nx"&gt;persona_1&lt;/span&gt; &lt;span class="o"&gt;=&lt;/span&gt; &lt;span class="k"&gt;new&lt;/span&gt; &lt;span class="nx"&gt;Persona&lt;/span&gt;&lt;span class="p"&gt;(&lt;/span&gt;&lt;span class="dl"&gt;'&lt;/span&gt;&lt;span class="s1"&gt;John Doe&lt;/span&gt;&lt;span class="dl"&gt;'&lt;/span&gt;&lt;span class="p"&gt;,&lt;/span&gt; &lt;span class="mi"&gt;34&lt;/span&gt;&lt;span class="p"&gt;)&lt;/span&gt;
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;p&gt;&lt;a href="https://i.giphy.com/media/Um3ljJl8jrnHy/giphy.gif" class="article-body-image-wrapper"&gt;&lt;img src="https://i.giphy.com/media/Um3ljJl8jrnHy/giphy.gif" alt="https://media.giphy.com/media/Um3ljJl8jrnHy/giphy.gif" width="263" height="172"&gt;&lt;/a&gt;&lt;/p&gt;

&lt;p&gt;Ahora crear personas es mucho mas fácil que antes! Ya no debería preocuparte si te pido que tu programa tenga varias personas, podes hacer uso de tu clase para instanciarlas muy sencillamente con el operador &lt;code&gt;new&lt;/code&gt; el cual siempre que lo veas significa que estas creando un nuevo objeto a partir de una clase o función constructora.&lt;/p&gt;

&lt;p&gt;Hablemos un poco de lo que te confunde de ese código, el constructor y la palabra &lt;code&gt;this&lt;/code&gt;. El constructor, como lo indica su nombre, es el responsable de crear el objeto, y entre los paréntesis vas a ver los parámetros de tu clase, en este caso &lt;code&gt;nombre&lt;/code&gt; y &lt;code&gt;edad&lt;/code&gt;, el constructor es una función, por eso es que después de su lista de parámetros creamos el cuerpo de la función, como sabrás ahí es donde sucede la acción, pero que estamos haciendo? de que se trata &lt;code&gt;this.nombre = nombre&lt;/code&gt; ? la palabra &lt;code&gt;this&lt;/code&gt; &lt;em&gt;en esta oportunidad&lt;/em&gt; esta vinculado a la instancia que estas creando, cada vez que quieras referenciar a las propiedades de tu clase tienes que hacerlo mediante &lt;code&gt;this&lt;/code&gt; .&lt;/p&gt;

&lt;p&gt;En pocas palabras, lo que estamos haciendo en el constructor es tomar los parámetros que nos pasan cuando usan a nuestra clase, &lt;code&gt;nombre&lt;/code&gt; y &lt;code&gt;edad&lt;/code&gt; y guardándolos como propiedades de nuestra clase en&lt;code&gt;this.nombre&lt;/code&gt; y en &lt;code&gt;this.edad&lt;/code&gt;.&lt;/p&gt;

&lt;p&gt;Hasta el momento sabes de que se trata este tipo de dato y como te puede ayudar a tener el código ordenado y como podemos usar clases para tener objetos predecibles pero falta algo muy importante, hablamos de propiedades, pero nuestros objetos ademas de tener propiedades pueden tener &lt;strong&gt;métodos.&lt;/strong&gt; Los métodos no son nada nuevo, simplemente son funciones que forman parte de un objeto. Agreguemos una función para &lt;code&gt;envejecer&lt;/code&gt; así podemos festejar el cumpleaños de John 🥳&lt;br&gt;
&lt;/p&gt;

&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight jsx"&gt;&lt;code&gt;&lt;span class="kd"&gt;class&lt;/span&gt; &lt;span class="nx"&gt;Persona&lt;/span&gt; &lt;span class="p"&gt;{&lt;/span&gt;
  &lt;span class="kd"&gt;constructor&lt;/span&gt;&lt;span class="p"&gt;(&lt;/span&gt;&lt;span class="nx"&gt;nombre&lt;/span&gt;&lt;span class="p"&gt;,&lt;/span&gt; &lt;span class="nx"&gt;edad&lt;/span&gt;&lt;span class="p"&gt;)&lt;/span&gt; &lt;span class="p"&gt;{&lt;/span&gt;
    &lt;span class="k"&gt;this&lt;/span&gt;&lt;span class="p"&gt;.&lt;/span&gt;&lt;span class="nx"&gt;nombre&lt;/span&gt; &lt;span class="o"&gt;=&lt;/span&gt; &lt;span class="nx"&gt;nombre&lt;/span&gt;&lt;span class="p"&gt;;&lt;/span&gt;
    &lt;span class="k"&gt;this&lt;/span&gt;&lt;span class="p"&gt;.&lt;/span&gt;&lt;span class="nx"&gt;edad&lt;/span&gt; &lt;span class="o"&gt;=&lt;/span&gt; &lt;span class="nx"&gt;edad&lt;/span&gt;&lt;span class="p"&gt;;&lt;/span&gt;
  &lt;span class="p"&gt;}&lt;/span&gt;

  &lt;span class="nx"&gt;envejecer&lt;/span&gt;&lt;span class="p"&gt;()&lt;/span&gt; &lt;span class="p"&gt;{&lt;/span&gt;
    &lt;span class="k"&gt;this&lt;/span&gt;&lt;span class="p"&gt;.&lt;/span&gt;&lt;span class="nx"&gt;edad&lt;/span&gt; &lt;span class="o"&gt;=&lt;/span&gt; &lt;span class="k"&gt;this&lt;/span&gt;&lt;span class="p"&gt;.&lt;/span&gt;&lt;span class="nx"&gt;edad&lt;/span&gt; &lt;span class="o"&gt;+&lt;/span&gt; &lt;span class="mi"&gt;1&lt;/span&gt;&lt;span class="p"&gt;;&lt;/span&gt;
  &lt;span class="p"&gt;}&lt;/span&gt;
&lt;span class="p"&gt;}&lt;/span&gt; 

&lt;span class="kd"&gt;let&lt;/span&gt; &lt;span class="nx"&gt;persona_1&lt;/span&gt; &lt;span class="o"&gt;=&lt;/span&gt; &lt;span class="k"&gt;new&lt;/span&gt; &lt;span class="nx"&gt;Persona&lt;/span&gt;&lt;span class="p"&gt;(&lt;/span&gt;&lt;span class="dl"&gt;'&lt;/span&gt;&lt;span class="s1"&gt;John Doe&lt;/span&gt;&lt;span class="dl"&gt;'&lt;/span&gt;&lt;span class="p"&gt;,&lt;/span&gt; &lt;span class="mi"&gt;34&lt;/span&gt;&lt;span class="p"&gt;);&lt;/span&gt;

&lt;span class="nx"&gt;persona_1&lt;/span&gt;&lt;span class="p"&gt;.&lt;/span&gt;&lt;span class="nx"&gt;edad&lt;/span&gt; &lt;span class="c1"&gt;// =&amp;gt; 34&lt;/span&gt;

&lt;span class="c1"&gt;// Llamemos a la funcion y veamos como incrementa su edad&lt;/span&gt;
&lt;span class="nx"&gt;persona_1&lt;/span&gt;&lt;span class="p"&gt;.&lt;/span&gt;&lt;span class="nx"&gt;envejecer&lt;/span&gt;&lt;span class="p"&gt;();&lt;/span&gt;

&lt;span class="nx"&gt;persona_1&lt;/span&gt;&lt;span class="p"&gt;.&lt;/span&gt;&lt;span class="nx"&gt;edad&lt;/span&gt; &lt;span class="c1"&gt;// =&amp;gt; 35 John cumplió 35 años!&lt;/span&gt;
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;p&gt;Ahora las personas de nuestro programa pueden envejecer. Ya podes empezar a modelar tus programas con este paradigma y sacar provecho de sus beneficios.&lt;/p&gt;

&lt;p&gt;&lt;a href="https://res.cloudinary.com/practicaldev/image/fetch/s--rYjKciJQ--/c_limit%2Cf_auto%2Cfl_progressive%2Cq_auto%2Cw_800/https://dev-to-uploads.s3.amazonaws.com/i/k1v7ct34e4rd0x7bber6.png" class="article-body-image-wrapper"&gt;&lt;img src="https://res.cloudinary.com/practicaldev/image/fetch/s--rYjKciJQ--/c_limit%2Cf_auto%2Cfl_progressive%2Cq_auto%2Cw_800/https://dev-to-uploads.s3.amazonaws.com/i/k1v7ct34e4rd0x7bber6.png" alt="A software engineer working" width="800" height="446"&gt;&lt;/a&gt;&lt;/p&gt;

&lt;p&gt;Esto fue tan solo una muy breve introducción al paradigma de la programación orientada a objetos. Queres saber por donde continuar?&lt;/p&gt;

&lt;p&gt;&lt;a href="https://javascript.info/object"&gt;javascript.info: Objects&lt;/a&gt;&lt;/p&gt;

&lt;p&gt;&lt;a href="https://developer.mozilla.org/en-US/docs/Learn/JavaScript/Objects/Object-oriented_JS"&gt;mozilla: Object-oriented JavaScript for beginners&lt;/a&gt;&lt;/p&gt;

&lt;p&gt;&lt;a href="https://www.freecodecamp.org/news/how-javascript-implements-oop/"&gt;freecodecamp: Object Oriented Programming in JavaScript - Explained with Examples&lt;/a&gt;&lt;/p&gt;

&lt;p&gt;&lt;a href="https://eloquentjavascript.net/1st_edition/chapter8.html"&gt;eloquentJS: Object-oriented Programming -- Eloquent JavaScript&lt;/a&gt;&lt;/p&gt;

</description>
      <category>spanish</category>
      <category>javascript</category>
      <category>oop</category>
      <category>es6</category>
    </item>
  </channel>
</rss>
