<?xml version="1.0" encoding="UTF-8"?>
<rss xmlns:dc="http://purl.org/dc/elements/1.1/" xmlns:content="http://purl.org/rss/1.0/modules/content/"
    xmlns:atom="http://www.w3.org/2005/Atom" xmlns:media="http://search.yahoo.com/mrss/" version="2.0">
    <channel>
        
        <title>
            <![CDATA[ Babel - freeCodeCamp.org ]]>
        </title>
        <description>
            <![CDATA[ Descubre miles de cursos de programación escritos por expertos. Aprende Desarrollo Web, Ciencia de Datos, DevOps, Seguridad y obtén asesoramiento profesional para desarrolladores. ]]>
        </description>
        <link>https://www.freecodecamp.org/espanol/news/</link>
        <image>
            <url>https://cdn.freecodecamp.org/universal/favicons/favicon.png</url>
            <title>
                <![CDATA[ Babel - freeCodeCamp.org ]]>
            </title>
            <link>https://www.freecodecamp.org/espanol/news/</link>
        </image>
        <generator>Eleventy</generator>
        <lastBuildDate>Wed, 03 Jun 2026 21:24:06 +0000</lastBuildDate>
        <atom:link href="https://www.freecodecamp.org/espanol/news/tag/babel/rss.xml" rel="self" type="application/rss+xml" />
        <ttl>60</ttl>
        
            <item>
                <title>
                    <![CDATA[ ¿Qué es Babel? ]]>
                </title>
                <description>
                    <![CDATA[ En el tercer artículo de esta serie sobre herramientas orientadas a la experiencia de desarrollador revisamos Babel. Puedes encontrar los artículos previos en:  * ¿Qué es Linting y ESLint? [/espanol/news/que-es-linting-y-eslint/]  * ¿Qué es npm? [/espanol/news/que-es-npm/] ¿Qué es Babel? Babel es un "compilador" (o transpilador) para JavaScript. Básicamente permite ]]>
                </description>
                <link>https://www.freecodecamp.org/espanol/news/que-es-babel/</link>
                <guid isPermaLink="false">604606ddc2765408ef8dd9aa</guid>
                
                    <category>
                        <![CDATA[ Babel ]]>
                    </category>
                
                <dc:creator>
                    <![CDATA[ Matias Hernandez ]]>
                </dc:creator>
                <pubDate>Tue, 09 Mar 2021 08:01:54 +0000</pubDate>
                <media:content url="https://www.freecodecamp.org/espanol/news/content/images/2021/03/English-Header-2-1-.png" medium="image" />
                <content:encoded>
                    <![CDATA[ <p>En el tercer artículo de esta serie sobre herramientas orientadas a la experiencia de desarrollador revisamos <strong>Babel.</strong></p><p>Puedes encontrar los artículos previos en:</p><ul><li><a href="https://www.freecodecamp.org/espanol/news/que-es-linting-y-eslint/">¿Qué es Linting y ESLint?</a></li><li><a href="https://www.freecodecamp.org/espanol/news/que-es-npm/">¿Qué es npm?</a></li></ul><h1 id="-qu-es-babel">¿Qué es Babel?</h1><p>Babel es un "<strong>compilador"</strong> (o transpilador) para JavaScript. Básicamente permite transformar código escrito con las últimas y novedosas características de JavaScript y transformarlo en un código que sea entendido por navegadores más antiguos.</p><h2 id="-por-qu-es-necesario-transformar-el-c-digo-javascript">¿Por qué es necesario transformar el código JavaScript?</h2><p>JavaScript es un lenguaje que no para de evolucionar y que cada año agrega nuevas características a su estándar. El estándar de JavaScript, conocido como ECMAScript.</p><p>ECMAScript (o abreviado ES) es la especificación en la que se basa JavaScript. ES nace de la organización ECMA International, cuyo objetivo es desarrollar estándares y reportes técnicos para facilitar el uso de tecnologías de la información.</p><p>Esta organización se constituye de varios equipos siendo el TC39 el equipo encargado de revisar, proponer y definir las características que el estándar tendrá cada año.</p><p>Lamentablemente la velocidad de actualización del estándar no es la misma que la velocidad de adopción de los navegadores, es decir, los navegadores no siempre pueden implementar las nuevas características en sus engine, ni tampoco hacerlo retrocompatible con versiones más antiguas. Además, tampoco es posible asegurar que todos los usuarios estén utilizando navegadores modernos o de última generación lo que imposibilita tener la seguridad de que podamos hacer uso de las nuevas características del lenguaje en todas partes.</p><h3 id="-qu-ventajas-tiene-el-utilizar-las-nuevas-caracter-sticas-propuestas-por-ecma">¿Qué ventajas tiene el utilizar las nuevas características propuestas por ECMA?</h3><p>Las nuevas características y "habilidades" que JavaScript provee cada año son sobre todo ventajas para ti como desarrollador, ya que te proporciona de herramientas más poderosas y expresivas para implementar soluciones a problemas complejos. Algunas de las características se han ido agregando con los años son:</p><ul><li>Funciones flechas (arrow functions)</li><li>Plantillas Literales (Template Literals)</li><li>Map y Set</li><li>Let y Const</li><li>Clases</li><li>Encadenamiento Opcional (Optional Chaining)</li><li>Operador Fusión Nula (Nullish Coalescing)</li><li>Métodos Privados (ES2021)</li><li>Operador de Asignación Local (ES2021)</li><li>Puedes ver más en la especificación actual de ECMA en: <a href="https://www.ecma-international.org/publications-and-standards/standards/ecma-262/">https://www.ecma-international.org/publications-and-standards/standards/ecma-262/</a></li></ul><h2 id="-entonces-como-puedo-usar-las-nuevas-versiones-de-javascript">¿Entonces como puedo usar las nuevas versiones de JavaScript?</h2><p>Ya que no todos los navegadores pueden interpretar o entender las nuevas características del lenguaje que estás o quieres usar es necesario buscar algunas soluciones, una de ellas es el uso de polyfills o librerías que implementan con código "antiguo" el mismo comportamiento que lo que intentas expresar con características nuevas, un ejemplo de esto es el polyfill para usar <a href="https://developer.mozilla.org/es/docs/Web/JavaScript/Reference/Global_Objects/Object/keys#polyfill">Object.keys</a></p><p>Pero si necesitas usar algo más que un par de operadores entonces entra en juego más requerimientos y aquí es donde <strong>Babel</strong> hace su aparición</p><p><strong>Babel</strong> permite transformar código de versiones nuevas de ES (ECMA2015+) a versiones retrocompatibles de JavaScript, esto lo realiza mediante:</p><ul><li>Transformaciones de sintaxis</li><li>Polyfills</li><li>Transformaciones de código fuente (codemods)</li><li>etc</li></ul><blockquote>Si lo que gustas es saber más sobre compiladores y como funciona babel en el alto nivel puedes revisar <a href="https://github.com/jamiebuilds/the-super-tiny-compiler">The super tiny compiler</a></blockquote><p>Babel es entonces una herramienta que lee tu código (archivo por archivo) y genera nuevo código que puedes usar en navegadores antiguos (o como entrada para algún bundler como webpack, rollup, etc)</p><p>Babel es casi omnipresente, utilizado por el 99.9% de los equipos que desarrolla software utilizando JavaScript, además Babel se alinea directamente a las discusiones del <a href="https://github.com/tc39/ecma262#ecmascript">TC39</a> proveyendo así implementaciones de propuestas que aún ni siquiera son aceptadas por el comité, lo que te permite tener dichas funcionalidades mucho antes incluso que los navegadores.</p><h2 id="-c-mo-funciona-babel">¿Cómo funciona Babel?</h2><p>Revisaremos de forma breve como babel funciona convirtiendo tu código de una versión a otra.</p><p>Considera este pequeño trozo de código JavaScript</p><pre><code class="language-jsx">const sum = (a, b) =&gt; a + b
</code></pre><p>Ahora considera que por alguna razón necesitas que este se ejecute en un navegador antiguo, entonces deberás transformarlo a</p><pre><code class="language-jsx">'use strict';
function sum(a,b) {
	return a + b;
}
</code></pre><p>¿Cómo se logra esto?</p><p>Es un proceso que se ejecuta en al menos 3 procesos</p><p>Parsing: Babel toma el código fuente, lo lee y lo convierte en una representación abstracta conocida como AST (Abstract Syntax Tree). Esta es una representación donde cada nodo del árbol representa una estructura del código fuente. Babel utiliza <a href="https://github.com/babel/babel/tree/master/packages/babel-parser">Babylon</a> para este trabajo.</p><p>Puedes ver el AST de nuestro ejemplo visitando <a href="https://astexplorer.net/#/gist/88e097f017a6b82f62dda743f91833da/latest">astexplorer.net</a></p><ol><li>Transformación: En esta etapa Babel trabaja sobre el AST generado en el proceso anterior y lo manipula para generar un nuevo AST que represente el código necesario para el soporte seleccionado.</li></ol><p>Este paso es realizado por una serie de "plugins" que permiten ejecutar varias transformaciones de forma sencilla y atómica. Aquí cada plugin toma el AST generado por el previo para aplicar una pequeña transformación.</p><blockquote>Puedes revisar como funciona el plugin <code>[babel-plugin-transform-arrow-function](&lt;https://github.com/babel/babel/tree/master/packages/babel-plugin-transform-arrow-functions&gt;)</code> o leer el "<a href="https://github.com/thejameskyle/babel-handbook/blob/master/translations/en/plugin-handbook.md#introduction">libro de mano de los plugin de babel</a>" (en inglés) para saber como funcionan o como implementar tu propio plugin</blockquote><ol><li>Generación de código: En esta etapa, babel toma el AST generado y crea/escribe el código compatible, es decir, crea ese trozo de código soportado por navegadores más antiguos.</li></ol><pre><code class="language-jsx">'use strict';
function sum(a,b) {
	return a + b;
}
</code></pre><h1 id="instalar-y-configurar-babel">Instalar y configurar Babel</h1><p>Ya sabemos que hace y hasta cierto punto como funciona babel, es hora de hacer uso de su poder, para eso lo primero es instalarlo en nuestro equipo. Para eso necesitamos utilizar el manejador de dependencias de node <strong><a href="https://www.freecodecamp.org/espanol/news/que-es-npm/">npm</a></strong></p><pre><code class="language-jsx">npm install --save-dev @babel/core @babel/cli
</code></pre><blockquote>Si no tienes el archivo package.json creado, crea uno antes de instalar dependencias. <code>npm init</code> te ayudará.</blockquote><p>Una vez instalado esto, verás las nuevas dependencias de desarrollo en tu archivo <code>package.json</code></p><p>Ahora para ejecutar babel puedes intentarlo directamente en la consola accediendo al binario dentro de la carpeta de instalación o utilizar las bondades de npm y su archivo de configuración al crear algunos scripts que te permitan ejecutarlo fácilmente.</p><p>Simplemente agrega la sección <code>scripts</code> y define el comando <code>build.</code></p><pre><code class="language-jsx">"scripts": {
	"build": "babel src -d lib"
}
</code></pre><p>Este comando le indica a babel que lea todo el contenido del directorio <code>src</code> y que genere la salida en el directorio <code>lib</code>.</p><p>Ahora para ejecutar solo basta utilizar npm.</p><pre><code class="language-jsx">npm run build
</code></pre><p>Si ejecutas esto utilizando el breve código de ejemplo de este artículo verás que babel hizo absolutamente nada, esto es porque la configuración por defecto de babel no define qué se debe hacer. Como comenté más arriba, Babel utiliza un sistema de plugins para definir las transformaciones que necesitas realizar.</p><h2 id="configurando-babel">Configurando Babel</h2><p>La configuración de babel se realiza utilizando un archivo de configuración, nada nuevo bajo el sol, llamado <code>babel.config.js</code> Un archivo JavaScript que retornará un objeto con la configuración deseada. El hecho de ser un archivo JavaScript te permite "calcular" ciertos parámetros como por ejemplo, utilizando variables de entorno.</p><p>Babel distribuye un "set" de configuraciones pre-definidas llamadas <code>presets</code>. Estos son básicamente un conjunto de plugins comúnmente utilizados que te permiten iniciar rápidamente.</p><p>Primer instalamos el paquete</p><pre><code class="language-jsx"> npm install @babel/preset-env --save-dev
</code></pre><p>Y luego definimos su uso en el archivo de configuración</p><pre><code class="language-jsx">{
  "presets": ["@babel/preset-env"]
}
</code></pre><p>Este preset es "inteligente" y decide qué plugins se usarán (y por ende que transformaciones se aplicaran) en base a la configuración de ambientes que quieres soportar. Dado que no especificamos ningún ambiente objetivo, babel asumirá que queremos transformar todo el código de versiones ES2015 en adelante en código compatible con ES5. No se recomienda utilizar babel de esta manera ya que estarás transformando código que probablemente los navegadores de tus usuarios ya soportan.</p><p>En nuestro particular y sencillo ejemplo, la transformación para soportar ES5 es convertir la función flecha en una función normal, puedes ver el resultado <a href="https://babeljs.io/repl#?browsers=defaults&amp;build=&amp;builtIns=false&amp;spec=false&amp;loose=false&amp;code_lz=MYewdgzgLgBBCuBbGBeGAKAhgGhgIwEpUA-GTGAanwCgg&amp;debug=false&amp;forceAllTransforms=false&amp;shippedProposals=false&amp;circleciRepo=&amp;evaluate=false&amp;fileSize=false&amp;timeTravel=false&amp;sourceType=module&amp;lineWrap=true&amp;presets=env&amp;prettier=false&amp;targets=&amp;version=7.13.9&amp;externalPlugins=">aquí</a> pero, las funciones flechas ya son <a href="https://caniuse.com/arrow-functions">soportadas por la gran mayoría de navegadores actuales</a> por lo que no tiene sentido hacer la transformación</p><p>Para decirle a babel que queremos soportar navegadores un poco más modernos podemos pasar un nuevo parámetro de configuración.</p><p>Babel se integra con <a href="https://github.com/browserslist/browserslist">browserlist</a> que no es más que una nomenclatura de configuración para definir qué navegadores o ambientes de node deben ser soportados por distintas herramientas. Para su uso se recomienda crear un nuevo archivo llamado <code>.browserlistrc</code> en donde pues escribir la lista de navegadores soportados.</p><p>Creemos el archivo de configuración y digamos que queremos soportar una lista de navegadores bastante nuevos, por ejemplo, que considere las estadísticas de uso y soporte todos los navegadores que tengan una porción de uso superior al 2%.</p><pre><code class="language-jsx">&gt; 2%
</code></pre><p>Ahora al ejecutar <code>npm run build</code> nuevamente veremos que el resultado es que nuestra función flecha no fue modificada (Puedes ver el <a href="https://babeljs.io/repl#?browsers=%3E%202%25&amp;build=&amp;builtIns=false&amp;spec=false&amp;loose=false&amp;code_lz=MYewdgzgLgBBCuBbGBeGAKAhgGhgIwEpUA-GTGAanwCgg&amp;debug=false&amp;forceAllTransforms=false&amp;shippedProposals=false&amp;circleciRepo=&amp;evaluate=false&amp;fileSize=false&amp;timeTravel=false&amp;sourceType=module&amp;lineWrap=true&amp;presets=env&amp;prettier=false&amp;targets=&amp;version=7.13.9&amp;externalPlugins=">ejemplo aquí</a>)</p><h2 id="conclusi-n">Conclusión</h2><p>En resumen babel es una herramienta necesaria hoy en día para así poder aprovechar todo el poder de las nuevas versiones de JavaScript mientras desarrollas sin preocuparte si los navegadores soportan o no dicha característica.</p><p>Su configuración más común es sencilla, simplemente utilizas el plugin <code>preset-env</code> y configuras los navegadores que quieres soportar. Siempre puedes ir más allá e ir agregando plugins para, incluso, soportar características que aún son solo una propuesta.</p><p>Por lo general no ejecutas babel directamente si no, como parte de un sistema de transformación a producción más grande que incluye algún bundler como webpack, rollup, vite, etc.</p><h3 id="saber-m-s">Saber más</h3><ul><li>Puedes encontrar más información sobre que es ES6 y TC39 en este episodio de <a href="https://www.cafecon.tech/1081172/3872285-que-es-es6">Café con Tech Podcast</a></li><li>Encuentra más información sobre TC39 <a href="https://www.freecodecamp.org/news/tc39-and-its-contributions-to-ecmascript-c178b77f32e1/">en este artículo de Freecodecamp en inglés.</a></li></ul><figure class="kg-card kg-image-card"><img src="https://www.freecodecamp.org/espanol/news/content/images/2021/03/Footer-Social-Card.jpg" class="kg-image" alt="Footer-Social-Card" srcset="https://www.freecodecamp.org/espanol/news/content/images/size/w600/2021/03/Footer-Social-Card.jpg 600w, https://www.freecodecamp.org/espanol/news/content/images/size/w1000/2021/03/Footer-Social-Card.jpg 1000w, https://www.freecodecamp.org/espanol/news/content/images/size/w1600/2021/03/Footer-Social-Card.jpg 1600w, https://www.freecodecamp.org/espanol/news/content/images/size/w2400/2021/03/Footer-Social-Card.jpg 2400w" sizes="(min-width: 720px) 720px" width="2000" height="533" loading="lazy"></figure><p>✉️ Únete a Micro-bytes &nbsp; &nbsp; &nbsp; &nbsp; 		? <a href="https://twitter.com/matiasfha">Sígueme en Twitter</a> &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; ❤️ <a href="https://buymeacoffee.com/matiasfha">Apoya mi trabajo</a> &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; newsletter de micro cursos</p> ]]>
                </content:encoded>
            </item>
        
    </channel>
</rss>
