<?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: Franco Gomez</title>
    <description>The latest articles on DEV Community by Franco Gomez (@gomezfrannco).</description>
    <link>https://dev.to/gomezfrannco</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%2F919359%2F457e6d46-9d96-441d-85c5-dbb78f3a43f0.png</url>
      <title>DEV Community: Franco Gomez</title>
      <link>https://dev.to/gomezfrannco</link>
    </image>
    <atom:link rel="self" type="application/rss+xml" href="https://dev.to/feed/gomezfrannco"/>
    <language>en</language>
    <item>
      <title>JavaScript: ¿Qué es el Execution Context?</title>
      <dc:creator>Franco Gomez</dc:creator>
      <pubDate>Sat, 14 Jan 2023 21:59:41 +0000</pubDate>
      <link>https://dev.to/gomezfrannco/javascript-que-es-el-execution-context-3254</link>
      <guid>https://dev.to/gomezfrannco/javascript-que-es-el-execution-context-3254</guid>
      <description>&lt;h2&gt;
  
  
  &lt;strong&gt;Introducción 📜&lt;/strong&gt;
&lt;/h2&gt;

&lt;p&gt;En el momento que me decidí por investigar conceptos un poco más avanzados de &lt;strong&gt;JavaScript&lt;/strong&gt; me di cuenta de lo poco que conocía sobre el lenguaje hasta ese momento.&lt;br&gt;
En este post describo de manera amigable qué es el &lt;strong&gt;Execution Context&lt;/strong&gt;, como es su funcionamiento y para qué sirve, entre otras cosas.&lt;/p&gt;
&lt;h2&gt;
  
  
  ¿Execution Context? &lt;strong&gt;🤔&lt;/strong&gt;
&lt;/h2&gt;

&lt;p&gt;En JavaScript, el contexto de ejecución o &lt;strong&gt;Execution Context&lt;/strong&gt; se refiere al entorno en donde una función o porción de código está siendo ejecutado. &lt;/p&gt;

&lt;p&gt;Dentro del &lt;strong&gt;Runtime&lt;/strong&gt; de JavaScript, cada vez que se ejecuta una función o script, se crea un nuevo contexto de ejecución que contiene información sobre las variables, funciones y objetos que están disponibles en ese momento.&lt;/p&gt;

&lt;p&gt;Cada contexto de ejecución tiene 2 fases:&lt;/p&gt;

&lt;ul&gt;
&lt;li&gt;
&lt;strong&gt;Fase de creación&lt;/strong&gt;.&lt;/li&gt;
&lt;li&gt;
&lt;strong&gt;Fase de ejecución&lt;/strong&gt;.&lt;/li&gt;
&lt;/ul&gt;
&lt;h3&gt;
  
  
  Fase de creación 🏗
&lt;/h3&gt;

&lt;p&gt;Por ejemplo, cuando el motor de &lt;strong&gt;JavaScript&lt;/strong&gt; ejecuta un script por primera vez, este crea un contexto de ejecución global. Durante fase de creación, el motor de &lt;strong&gt;JavaScript&lt;/strong&gt; realiza las siguientes tareas:&lt;/p&gt;

&lt;ul&gt;
&lt;li&gt;Crea el objeto global, es decir, &lt;code&gt;window&lt;/code&gt; si es en el navegador o &lt;code&gt;global&lt;/code&gt; si es en Node.js.&lt;/li&gt;
&lt;li&gt;Crea el objeto &lt;code&gt;this&lt;/code&gt; y lo vincula al objeto global.&lt;/li&gt;
&lt;li&gt;Configura la memoria para almacenar &lt;strong&gt;variables&lt;/strong&gt; y referencias a &lt;strong&gt;funciones&lt;/strong&gt;.&lt;/li&gt;
&lt;li&gt;Almacena las declaraciones de funciones y variables en memoria dentro del contexto de ejecución global pero con valores iniciales como &lt;code&gt;undefined&lt;/code&gt;.&lt;/li&gt;
&lt;/ul&gt;

&lt;p&gt;Luego de esta fase de creación, el contexto de ejecución global pasa a la fase de ejecución.&lt;/p&gt;
&lt;h3&gt;
  
  
  Fase de ejecución ⚡
&lt;/h3&gt;

&lt;p&gt;Durante la fase de ejecución, el motor de &lt;strong&gt;JavaScript&lt;/strong&gt; ejecuta el código línea tras línea asignando los valores a las variables y ejecutando las llamadas a las funciones.&lt;/p&gt;

&lt;p&gt;Para cada llamado a una función, el motor de &lt;strong&gt;JavaScript&lt;/strong&gt; crea otro contexto de ejecución llamado &lt;strong&gt;function execution context&lt;/strong&gt;.&lt;/p&gt;

&lt;p&gt;Estos contextos son muy similares al contexto de ejecución global, pero en lugar de crear el objeto global &lt;code&gt;window&lt;/code&gt;, el motor de &lt;strong&gt;JavaScript&lt;/strong&gt; crea el objeto &lt;code&gt;arguments&lt;/code&gt; refiriendose a los parámetros de la función.&lt;/p&gt;
&lt;h2&gt;
  
  
  &lt;strong&gt;Ejemplo 🔍&lt;/strong&gt;
&lt;/h2&gt;

&lt;p&gt;En este ejemplo voy a mostrar un pequeño código con el propósito de explicar el funcionamiento de lo anteriormente explicado:&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;number&lt;/span&gt; &lt;span class="o"&gt;=&lt;/span&gt; &lt;span class="mi"&gt;25&lt;/span&gt;&lt;span class="p"&gt;;&lt;/span&gt;

&lt;span class="kd"&gt;function&lt;/span&gt; &lt;span class="nf"&gt;timesTen&lt;/span&gt;&lt;span class="p"&gt;(&lt;/span&gt;&lt;span class="nx"&gt;a&lt;/span&gt;&lt;span class="p"&gt;){&lt;/span&gt;
    &lt;span class="k"&gt;return&lt;/span&gt; &lt;span class="nx"&gt;a&lt;/span&gt; &lt;span class="o"&gt;*&lt;/span&gt; &lt;span class="mi"&gt;10&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;result&lt;/span&gt; &lt;span class="o"&gt;=&lt;/span&gt; &lt;span class="nf"&gt;timesTen&lt;/span&gt;&lt;span class="p"&gt;(&lt;/span&gt;&lt;span class="nx"&gt;number&lt;/span&gt;&lt;span class="p"&gt;);&lt;/span&gt;

&lt;span class="nx"&gt;console&lt;/span&gt;&lt;span class="p"&gt;.&lt;/span&gt;&lt;span class="nf"&gt;log&lt;/span&gt;&lt;span class="p"&gt;(&lt;/span&gt;&lt;span class="nx"&gt;result&lt;/span&gt;&lt;span class="p"&gt;);&lt;/span&gt; &lt;span class="c1"&gt;// 250&lt;/span&gt;
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;h3&gt;
  
  
  Fase de creación 🏗
&lt;/h3&gt;

&lt;p&gt;En este caso, la fase de creación empezaría por crear el objeto global &lt;code&gt;window&lt;/code&gt; seguido del objeto &lt;code&gt;this&lt;/code&gt; para luego hacer lugar en memoria para almacenar las &lt;strong&gt;variables&lt;/strong&gt; y los llamados a las &lt;strong&gt;funciones.&lt;/strong&gt; Luego, empezaría por guardar las variables &lt;code&gt;number&lt;/code&gt; y &lt;code&gt;result&lt;/code&gt; y la declaración de &lt;code&gt;timesTen()&lt;/code&gt; dentro del contexto de ejecución global. Por último, inicializa las variables &lt;code&gt;number&lt;/code&gt; y &lt;code&gt;result&lt;/code&gt; como &lt;code&gt;undefined&lt;/code&gt;.&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;number&lt;/span&gt; &lt;span class="o"&gt;=&lt;/span&gt; &lt;span class="kc"&gt;undefined&lt;/span&gt;&lt;span class="p"&gt;;&lt;/span&gt;

&lt;span class="kd"&gt;function&lt;/span&gt; &lt;span class="nf"&gt;timesTen&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;result&lt;/span&gt; &lt;span class="o"&gt;=&lt;/span&gt; &lt;span class="kc"&gt;undefined&lt;/span&gt;&lt;span class="p"&gt;;&lt;/span&gt;

&lt;span class="nx"&gt;console&lt;/span&gt;&lt;span class="p"&gt;.&lt;/span&gt;&lt;span class="nf"&gt;log&lt;/span&gt;&lt;span class="p"&gt;(&lt;/span&gt;&lt;span class="nx"&gt;result&lt;/span&gt;&lt;span class="p"&gt;);&lt;/span&gt; &lt;span class="c1"&gt;// 250&lt;/span&gt;
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;h3&gt;
  
  
  Fase de ejecución ⚡
&lt;/h3&gt;

&lt;p&gt;Durante esta fase, el motor de &lt;strong&gt;JavaScript&lt;/strong&gt; ejecuta el código línea por línea asignando los valores &lt;code&gt;25&lt;/code&gt; y &lt;code&gt;timesTen(number)&lt;/code&gt; a las variables &lt;code&gt;number&lt;/code&gt; y &lt;code&gt;result&lt;/code&gt;.&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;number&lt;/span&gt; &lt;span class="o"&gt;=&lt;/span&gt; &lt;span class="mi"&gt;25&lt;/span&gt;&lt;span class="p"&gt;;&lt;/span&gt;

&lt;span class="kd"&gt;function&lt;/span&gt; &lt;span class="nf"&gt;timesTen&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;result&lt;/span&gt; &lt;span class="o"&gt;=&lt;/span&gt; &lt;span class="nf"&gt;timesTen&lt;/span&gt;&lt;span class="p"&gt;(&lt;/span&gt;&lt;span class="nx"&gt;number&lt;/span&gt;&lt;span class="p"&gt;);&lt;/span&gt;

&lt;span class="nx"&gt;console&lt;/span&gt;&lt;span class="p"&gt;.&lt;/span&gt;&lt;span class="nf"&gt;log&lt;/span&gt;&lt;span class="p"&gt;(&lt;/span&gt;&lt;span class="nx"&gt;result&lt;/span&gt;&lt;span class="p"&gt;);&lt;/span&gt; &lt;span class="c1"&gt;// 250&lt;/span&gt;
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;p&gt;(&lt;strong&gt;Esto puede resultar un poco más complicado de lo normal&lt;/strong&gt;)&lt;/p&gt;

&lt;p&gt;Luego crea un nuevo contexto de ejecución para la función &lt;code&gt;timesTen&lt;/code&gt; pasando una vez más por la fase de creación, en donde crea el objeto global &lt;code&gt;arguments&lt;/code&gt;, establece &lt;code&gt;this&lt;/code&gt; referenciando al objeto global e inicializando &lt;code&gt;a&lt;/code&gt; como &lt;code&gt;undefined&lt;/code&gt;.&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="cm"&gt;/* Function Execution Context */&lt;/span&gt;
&lt;span class="kd"&gt;function&lt;/span&gt; &lt;span class="nf"&gt;timesTen&lt;/span&gt;&lt;span class="p"&gt;(&lt;/span&gt;&lt;span class="nx"&gt;a&lt;/span&gt;&lt;span class="p"&gt;){&lt;/span&gt;   
    &lt;span class="c1"&gt;// this = windows (en este caso)&lt;/span&gt;
    &lt;span class="c1"&gt;// a = undefined&lt;/span&gt;
    &lt;span class="k"&gt;return&lt;/span&gt; &lt;span class="nx"&gt;a&lt;/span&gt; &lt;span class="o"&gt;*&lt;/span&gt; &lt;span class="mi"&gt;10&lt;/span&gt;
&lt;span class="p"&gt;}&lt;/span&gt;
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;p&gt;En la fase de ejecución del contexto de la función &lt;code&gt;timesTen&lt;/code&gt; (que se encuentra dentro del contexto global) el motor de &lt;strong&gt;JavaScript&lt;/strong&gt; asigna &lt;code&gt;25&lt;/code&gt; al parámetro &lt;code&gt;a&lt;/code&gt; retornando el valor &lt;code&gt;250&lt;/code&gt;, ahora sí, hacia el contexto de ejecución global 🤯🤯🤯🤯🤯🤯🤯🤯🤯&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;number&lt;/span&gt; &lt;span class="o"&gt;=&lt;/span&gt; &lt;span class="mi"&gt;25&lt;/span&gt;&lt;span class="p"&gt;;&lt;/span&gt;

&lt;span class="kd"&gt;function&lt;/span&gt; &lt;span class="nf"&gt;timesTen&lt;/span&gt;&lt;span class="p"&gt;(&lt;/span&gt;&lt;span class="nx"&gt;a&lt;/span&gt;&lt;span class="p"&gt;){&lt;/span&gt;
    &lt;span class="k"&gt;return&lt;/span&gt; &lt;span class="nx"&gt;a&lt;/span&gt; &lt;span class="o"&gt;*&lt;/span&gt; &lt;span class="mi"&gt;10&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;result&lt;/span&gt; &lt;span class="o"&gt;=&lt;/span&gt; &lt;span class="nf"&gt;timesTen&lt;/span&gt;&lt;span class="p"&gt;(&lt;/span&gt;&lt;span class="nx"&gt;number&lt;/span&gt;&lt;span class="p"&gt;);&lt;/span&gt;

&lt;span class="nx"&gt;console&lt;/span&gt;&lt;span class="p"&gt;.&lt;/span&gt;&lt;span class="nf"&gt;log&lt;/span&gt;&lt;span class="p"&gt;(&lt;/span&gt;&lt;span class="nx"&gt;result&lt;/span&gt;&lt;span class="p"&gt;);&lt;/span&gt; &lt;span class="c1"&gt;// 250&lt;/span&gt;
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;h2&gt;
  
  
  &lt;strong&gt;Posibles recomendaciones 🤓&lt;/strong&gt;
&lt;/h2&gt;

&lt;p&gt;Dado que es un poco difícil de entender el funcionamiento, me tomé el trabajo de dejarles dos recursos que me fueron de gran utilidad para que puedan entender más sobre el contexto de ejecución:&lt;/p&gt;

&lt;ul&gt;
&lt;li&gt;&lt;a href="https://www.freecodecamp.org/news/execution-context-how-javascript-works-behind-the-scenes/"&gt;https://www.freecodecamp.org/news/execution-context-how-javascript-works-behind-the-scenes/&lt;/a&gt;&lt;/li&gt;
&lt;li&gt;&lt;a href="https://medium.com/sngular-devs/comprende-js-entorno-l%C3%A9xico-y-el-contexto-de-ejecuci%C3%B3n-c66459f63321"&gt;https://medium.com/sngular-devs/comprende-js-entorno-léxico-y-el-contexto-de-ejecución-c66459f63321&lt;/a&gt;&lt;/li&gt;
&lt;/ul&gt;




&lt;p&gt;Muchas gracias por llegar hasta aquí, espero que hayas comprendido lo que he escrito en este post.&lt;/p&gt;

&lt;h3&gt;
  
  
  Sígueme si te ha sido de ayuda! 😸
&lt;/h3&gt;

</description>
      <category>webdev</category>
      <category>javascript</category>
      <category>beginners</category>
      <category>tutorial</category>
    </item>
    <item>
      <title>APIs: Explicando el Overfetching y Underfetching de manera amigable.</title>
      <dc:creator>Franco Gomez</dc:creator>
      <pubDate>Wed, 04 Jan 2023 05:02:06 +0000</pubDate>
      <link>https://dev.to/gomezfrannco/apis-explicando-el-overfetching-y-underfetching-de-manera-amigable-49ph</link>
      <guid>https://dev.to/gomezfrannco/apis-explicando-el-overfetching-y-underfetching-de-manera-amigable-49ph</guid>
      <description>&lt;p&gt;Liquid syntax error: 'raw' tag was never closed&lt;/p&gt;
</description>
      <category>php</category>
      <category>wordpress</category>
      <category>development</category>
    </item>
  </channel>
</rss>
