|
1 | 1 | # react-howto
|
2 | 2 |
|
3 |
| -If you’re new to React (or frontend in general) you may find the ecosystem confusing. There are a few reasons for this. |
| 3 | +Sí eres nuevo con React (o con el desarrollo front-end en general) puedes encontrar confuso su ecosistema. Existen unas cuantas razones para ello. |
4 | 4 |
|
5 |
| -* React has historically been targeted at early-adopters and experts |
6 |
| -* Facebook only open-sources what it actually uses, so it doesn’t focus on tooling for smaller-than-Facebook projects |
7 |
| -* There’s a lot of bad marketing masquerading as React guides |
| 5 | +* Históricamente React se ha enfocado en early-adopters y expertos |
| 6 | +* Facebook sólo libera lo que realmente usa, por lo que no se centra en herramientas para proyectos "más pequeños que Facebook" |
| 7 | +* Hay muchos artículos de marketing enmascarados como guías de React |
8 | 8 |
|
9 |
| -Throughout this document, I’ll assume you’ve built a web page with HTML, CSS and JavaScript. |
| 9 | +A lo largo de este documento, asumiré que has construido una página con HTML, CSS y JavaScript. |
10 | 10 |
|
11 |
| -## Why should you listen to me? |
| 11 | +## ¿Por qué escucharme a mí? |
12 | 12 |
|
13 |
| -There’s a ton of conflicting advice about React out there; why listen to me? |
| 13 | +Hay un montón de consejos conflictivos sobre React ahí fuera, ¿por qué escucharme a mí? |
14 | 14 |
|
15 |
| -I was one of the original members of the Facebook team that built and open-sourced React. I’m no longer at Facebook and I’m now at a small startup, so I have a non-Facebook perspective as well. |
| 15 | +Fui uno de los miembros del equipo original de Facebook que construyo y libero React. Ya no estoy en Facebook, ahora estoy en una pequeña startup, por lo que tengo también una perspectiva "no-Facebook". |
16 | 16 |
|
17 |
| -## How to tackle the React ecosystem |
| 17 | +## Cómo abordar el ecosistema de React |
18 | 18 |
|
19 |
| -All software is built on a stack of technologies, and you need to understand enough of that stack to build your app. The reason why the React ecosystem of tooling seems overwhelming is because it’s always explained in the wrong order. |
| 19 | +Todo software se construye con un stack tecnológico, y es necesario entender lo suficiente de ese stack para construir una aplicación. La razón por la que el ecosistema de herramientas de React parece abrumador es porque siempre ha sido explicado en el orden incorrecto. |
20 | 20 |
|
21 |
| -You should learn, in this order, **without skipping ahead or learning concurrently**: |
| 21 | +Debes aprenderlo en este orden, **sin saltarte ningún paso o hacerlo concurrentemente**: |
22 | 22 |
|
23 |
| -* [React itself](#learning-react-itself) |
| 23 | +* [React en sí](#learning-react-itself) |
24 | 24 | * [`npm`](#learning-npm)
|
25 | 25 | * [JavaScript “bundlers”](#learning-javascript-bundlers)
|
26 | 26 | * [ES6](#learning-es6)
|
27 |
| -* [Routing](#learning-routing) |
| 27 | +* [Enrutamiento](#learning-routing) |
28 | 28 | * [Flux](#learning-flux)
|
29 | 29 |
|
30 |
| -**You don't need to learn all of these to be productive with React.** Only move to the next step if you have a problem that needs to be solved. |
| 30 | +**No necesitas aprender todas ellas para ser productivo con React.** Sólo muévete al siguiente paso si tienes un problema que necesita ser resuelto. |
31 | 31 |
|
32 |
| -Additionally, there are a few topics that are often mentioned in the React community that are "bleeding edge". The topics below are interesting, but they're difficult to understand, are far less popular than the above topics and **aren't required for most apps**. |
33 |
| -* [Inline styles](#learning-inline-styles) |
34 |
| -* [Server rendering](#learning-server-rendering) |
| 32 | +Adicionalmente, hay unos cuantos temas que a menudo son categorizados en la comunidad de React como "bleeding edge"<sup>[1](#f1)</sup>. Los temas de abajo son interesantes, pero difíciles de entender, de lejos menos populares que los de arriba y **no son requeridos para la mayoría de aplicaciones**. |
| 33 | +* [Estilos inline](#learning-inline-styles) |
| 34 | +* [Renderizado en el servidor](#learning-server-rendering) |
35 | 35 | * [Immutable.js](#learning-immutablejs)
|
36 |
| -* [Relay, Falcor, etc](#learning-relay-falcor-etc) |
| 36 | +* [Relay, Falcor, etc.](#learning-relay-falcor-etc) |
37 | 37 |
|
38 |
| -## Learning React itself |
| 38 | +## Aprendiendo React en sí |
39 | 39 |
|
40 |
| -It’s a common misconception that you need to waste a lot of time setting up tooling to start to learn React. In the official documentation you’ll find a [copy-paste HTML template](https://facebook.github.io/react/docs/getting-started.html#quick-start-without-npm) that you can save in an `.html` file and get started right away. **No tooling is required for this step, and don’t start learning extra tooling until you’re comfortable with React basics.** |
| 40 | +Es un error común pensar que se necesita perder mucho tiempo preparando un entorno para comenzar a aprender React. En la documentación oficial encontrarás una [plantilla HTML de copia y pega](https://facebook.github.io/react/docs/getting-started.html#quick-start-without-npm) que puedes guardar en un fichero `.html` y empezar inmediatamente. **No se necesita ninguna herramienta para este paso, y no empieces a aprender herramientas extras hasta que no te sientas cómodo con lo básico de React.** |
41 | 41 |
|
42 |
| -I still think the easiest way to learn React is [the official tutorial](https://facebook.github.io/react/docs/tutorial.html). |
| 42 | +Todavía pienso que la forma más fácil de aprender React es [el tutorial oficial](https://facebook.github.io/react/docs/tutorial.html). |
43 | 43 |
|
44 |
| -## Learning `npm` |
| 44 | +## Aprendiendo `npm` |
45 | 45 |
|
46 |
| -`npm` is the Node.js package manager and is the most popular way front-end engineers and designers share JavaScript code. It includes a module system called `CommonJS` and lets you install command-line tools written in JavaScript. Read [this post](http://0fps.net/2013/01/22/commonjs-why-and-how/) for background on why `CommonJS` is necessary for browsers, or the [CommonJS Spec Wiki](http://wiki.commonjs.org/wiki/Introduction) for more on the `CommonJS` API. |
| 46 | +`npm` es el gestor de paquetes de Node.js y la forma más popular en la que diseñadores y desarrolladores de front-end comparten código JavaScript. Incluye un módulo de sistema llamado `CommonJS` y te permite instalar herramientas de línea de comando escritas en JavaScript. Lee [este artículo](http://0fps.net/2013/01/22/commonjs-why-and-how/) para entender porque `CommonJS` es necesario en los navegadores, o la [CommonJS Spec Wiki](http://wiki.commonjs.org/wiki/Introduction) para más información en la API de `CommonJS`. |
47 | 47 |
|
48 |
| -Most reusable components, libraries and tools in the React ecosystem are available as `CommonJS` modules and are installed with `npm`. |
| 48 | +La mayoría de componentes reusables, librerías y herramientas en el ecosistema de React están disponibles como módulos `CommonJS` y se instalan con `npm`. |
49 | 49 |
|
50 |
| -## Learning JavaScript bundlers |
| 50 | +## Aprendiendo JavaScript bundlers |
51 | 51 |
|
52 |
| -For a number of good technical reasons `CommonJS` modules (i.e. everything in `npm`) cannot be used natively in the browser. You need a JavaScript “bundler” to “bundle” these modules into `.js` files that you can include in your web page with a `<script>` tag. |
| 52 | +Por un buen número de razones técnicas los módulos `CommonJS` (p.ej. cualquiera en `npm`) no puede ser usado nativamente en el navegador. Necesitas un JavaScript “bundler” para "convertir" estos módulos en ficheros `.js` que puedas incluir en tus páginas web con un tag `<script>`. |
53 | 53 |
|
54 |
| -Examples of JavaScript bundlers include `webpack` and `browserify`. Both are good choices, but I prefer `webpack` since it has a lot of features that make development of large apps easier. Since its documentation can be confusing, I have a [plug-and-play template for getting started](https://github.com/petehunt/react-webpack-template) and I wrote a [how-to guide for webpack](https://github.com/petehunt/webpack-howto) for more complex use cases. |
| 54 | +Ejemplos de JavaScript bundlers incluye `webpack` y `browserify`. Ambos son buenas opciones, pero prefiero `webpack` ya que tiene muchas características que hacen el desarrollo de aplicaciones grandes más sencillo. Ya que su documentación puede ser confusa, tengo una [plantilla plug-and-play para empezar](https://github.com/petehunt/react-webpack-template) y escribí una [guía how-to para webpack](https://github.com/petehunt/webpack-howto) para casos de uso más complejos. |
55 | 55 |
|
56 |
| -One thing to keep in mind: `CommonJS` uses the `require()` function to import modules, so a lot of people get confused and think that it has something to do with a project called `require.js`. For a number of technical reasons, I would suggest that you avoid `require.js`. It’s also not very popular in the React ecosystem. |
| 56 | +Una cosa a tener en cuenta: `CommonJS` utiliza la función `require()` para importar modules, por lo que mucha gente se confunde y piensa que tiene algo que ver con un proyecto llamado `require.js`. Por una cuantas razones técnicas, te sugiero evites utilizar `require.js`. Además no es muy popular en el ecosistema de React. |
57 | 57 |
|
58 |
| -## Learning ES6 |
| 58 | +## Aprendiendo ES6 |
59 | 59 |
|
60 |
| -Outside of JSX (which you learned in the React tutorial), you may see some funny syntax in React examples. This is called ES6, and it’s the latest version of JavaScript so you may not have learned it yet. Since it’s so new, it’s not supported in browsers yet, but your bundler can translate it for you with the proper configuration. |
| 60 | +Aparte de JSX (el cual has aprendido en el tutorial de React), puede que encuentres sintaxis "divertida" en ejemplos de React. Esto se llama ES6, y es la última versión de JavaScript así que seguramente no lo hayas aprendido aún. Al ser tan nuevo, no está soportado en los navegadores aún, pero tu bundler puede traducirlo por ti con la configuración adecuada. |
61 | 61 |
|
62 |
| -If you just want to get things done with React, **you can skip learning ES6**, or try to pick it up along the way. |
| 62 | +Si únicamente quieres terminar las cosas con React, **puedes saltarte ES6**, o tratar de incorporarlo en el camino. |
63 | 63 |
|
64 |
| -## Learning routing |
| 64 | +## Aprendiendo enrutamiento |
65 | 65 |
|
66 |
| -“Single-page applications” are all the rage these days. These are web pages that load once, and when the user clicks on a link or a button, JavaScript running on the page updates the address bar, but the web page is not refreshed. Management of the address bar is done by something called a **router**. |
| 66 | +Las “single-page applications” (o aplicaciones de página única) son lo más estos días. Estas son páginas que se cargan una vez, y cuando el usuario hace click en un enlace o botón, el JavaScript corriendo en la página actualizar la barra de direcciones, pero la página web no es recargada. La gestión de la barra de direcciones es hecha por algo llamado **router**. |
67 | 67 |
|
68 |
| -The most popular router in the React ecosystem is [react-router](https://github.com/rackt/react-router). If you’re building a single-page application, use it unless you have a good reason not to. |
| 68 | +El router más popular en el ecosistema de React es [react-router](https://github.com/rackt/react-router). Si estás haciendo una aplicación de página única, úsalo a no ser que tengas una buena razón para no hacerlo. |
69 | 69 |
|
70 |
| -**Don’t use a router if you aren’t building a single-page application**. Most projects start out as smaller components inside of a larger application anyway. |
| 70 | +**No uses un router si no estás construyendo una aplicación de página única**. De cualquier manera la mayoría de proyectos comienzan cómo pequeños componentes dentro de una aplicación más grande. |
71 | 71 |
|
72 |
| -## Learning Flux |
| 72 | +## Aprendiendo Flux |
73 | 73 |
|
74 |
| -You’ve probably heard of Flux. There’s a *ton* of misinformation about Flux out there. |
| 74 | +Probablemente habrás oído hablar de Flux. Hay un *montón* de información errónea sobre Flux ahí fuera. |
75 | 75 |
|
76 |
| -A lot of people sit down to build an app and want to define their data model, and they think they need to use Flux to do it. **This is the wrong way to adopt Flux. Flux should only be added once many components have already been built.** |
| 76 | +Mucha gente se sienta a construir una aplicación y quiere definir su modelo de datos, y piensan que necesitan Flux para hacerlo. **Esta es la manera incorrecta de adoptar Flux. Flux sólo debería ser añadido una vez se han hecho ya algunos componentes.** |
77 | 77 |
|
78 |
| -React components are arranged in a hierarchy. Most of the time, your data model also follows a hierarchy. In these situations Flux doesn’t buy you much. Sometimes, however, your data model is not hierarchical. When your React components start to receive `props` that feel extraneous, or you have a small number of components starting to get very complex, then you might want to look into Flux. |
| 78 | +Los componentes de React están organizado en una jerarquía. La mayoría de las veces, tu modelo de datos también sigue una jerarquía. Es estas situaciones Flux no te aporta demasiado. A veces, sin embargo, tu modelo de datos no es jerárquico. Cuando tus componentes de React empiezan a recibir `props` que parecen extrañas, o tienes un pequeño número de componentes que empiezan a ser muy complejos, entonces puede que quieras considerar usar Flux. |
79 | 79 |
|
80 |
| -**You’ll know when you need Flux. If you aren’t sure if you need it, you don’t need it.** |
| 80 | +**Sabrás cuando necesitas Flux. Sí no estás seguro de si lo necesitas, es que no lo necesitas.** |
81 | 81 |
|
82 |
| -If you have decided to use Flux, the most popular and well-documented Flux library is [Redux](http://redux.js.org/). There are *a lot* of alternatives out there, and you’ll be tempted to evaluate lots of them, but my advice is to just stick with the most popular one. |
| 82 | +Si has decidido usar Flux, la librería más popular y bien documentada es [Redux](http://redux.js.org/). Hay *muchas* alternativas, y estarás tentado a evaluar muchas de ellas, pero mi consejo es que te quedes sólo con la más popular. |
83 | 83 |
|
84 |
| -## Learning inline styles |
| 84 | +## Aprendiendo estilos inline |
85 | 85 |
|
86 |
| -Pre-React, a lot of people reused CSS styles with complicated style sheets built by preprocessors like SASS. Since React makes writing reusable components easy, your stylesheets can be less complicated. Many in the community (including myself) are experimenting with getting rid of stylesheets altogether. |
| 86 | +Antes de React, mucha gente reusaba estilos de CSS con complicadas hojas de estilos construidas con preprocesadores cómo SASS. Ya que React hace sencillo escribir componentes reusables, tus hojas de estilo pueden ser menos complicadas. Muchos en la comunidad (incluido yo) están experimentando con deshacerse de las hojas de estilo del todo. |
87 | 87 |
|
88 |
| -This is a fairly crazy idea for a number of reasons. It makes media queries more difficult, and it's possible that there are performance limitations using this technique. **When starting out with React, just style things the way you normally would.** |
| 88 | +Esta es una idea bastante loca por un buen número de razones. Hace las media queries más complicadas, y es posible que existan limitaciones de rendimiento usando esta técnica. **Cuando empieces con React, sólo pone el estilo a las cosas de la forma que normalmente lo harías.** |
89 | 89 |
|
90 |
| -Once you've got a feel for how React works, you can look at alternate techniques. One popular one is [BEM](https://en.bem.info/). I recommend phasing out your CSS preprocessor, since React gives you a more powerful way to reuse styles (by reusing components) and your JavaScript bundler can generate more efficient stylesheets for you (I gave [a talk about this at OSCON](https://www.youtube.com/watch?v=VkTCL6Nqm6Y)). With that said, React, like any other JavaScript library, will work just fine with a CSS preprocessor. |
| 90 | +Una vez entiendes cómo funciona React, puedes considerar técnicas alternativas. Una de las más populares es [BEM](https://en.bem.info/). Te recomiendo reducir gradualmente tus pre-procesadores CSS, ya que React te ofrece una manera más potente de reusar los estilos (reutilizando componentes) y tu bundler de JavaScript puede generar hojas de estilos más eficientes por ti (di [una charla sobre esto en la OSCON](https://www.youtube.com/watch?v=VkTCL6Nqm6Y)). Dicho esto, React, como cualquier otra librería de JavaScript, funcionará bien con un pre-procesador CSS. |
91 | 91 |
|
92 |
| -## Learning server rendering |
| 92 | +## Aprendiendo renderizado en el servidor (server rendering) |
93 | 93 |
|
94 |
| -Server rendering is often called "universal" or "isomorphic" JS. It means that you can take your React components and render them to static HTML on the server. This improves initial startup perormance because the user does not need to wait for JS to download in order to see the initial UI, and React can re-use the server-rendered HTML so it doesn't need to generate it client-side. |
| 94 | +El renderizado en el servidor (o server rendering) es a menudo llamado JavaScript "universal" o "isomorfo". Esto significa que puedes tomar tus componentes de React y renderizarlos como HTML estático en el servidor. Es mejora el rendimiento de la carga inicial ya que el usuario no necesita esperar a que el JS sea descargado para ver la interfaz inicial, y React puede reusar el HTML renderizado en el servidor así que no necesita generarlo en el lado del cliente. |
95 | 95 |
|
96 |
| -You need server rendering if you notice that your initial render is too slow or if you want to improve your search engine ranking. While it's true that Google now indexes client-rendered content, as of January 2016 every time it's been measured it's been shown to negatively affect ranking, potentially because of the performance penalty of client-side rendering. |
| 96 | +Necesitas hacer renderizado en el servidor si te das cuentas que renderizado inicial es demasiado lento si quieres mejorar tu ranking en buscadores (Search Engine Ranking). Aunque es verdad que Google ahora indexa el contenido renderizado en el cliente, desde Enero de 2016 cada vez que se ha medido se ha visto que afecta negativamente al ranking, seguramente por la penalización de rendimiento del renderizado en cliente. |
97 | 97 |
|
98 |
| -Server rendering still requires a lot of tooling to get right. Since it transparently supports React components written without server rendering in mind, you should build your app first and worry about server rendering later. You won't need to rewrite all of your components to support it. |
| 98 | +El renderizado en el servidor todavía requiere de muchas herramientas para hacerlo bien. Ya que React soporta transparentemente que los componentes sean escritos sin el renderizado en servidor en mente, puedes construir una aplicación primero y preocuparte del renderizado en el servidor después. No necesitarás reescribir todos tus componentes para que funcione. |
99 | 99 |
|
100 |
| -## Learning Immutable.js |
| 100 | +## Aprendiendo Immutable.js |
101 | 101 |
|
102 |
| -[Immutable.js](https://facebook.github.io/immutable-js/) provides a set of data structures that can help to solve certain performance issues when building React apps. It's a great library, and you'll probably use it a lot in your apps moving forward, but it's completely unnecessary until you have an appreciation of the performance implications. |
| 102 | +[Immutable.js](https://facebook.github.io/immutable-js/) aporta una colección de estructuras de datos que ayudan a resolver ciertos problemas de rendimiento cuando se construyen aplicaciones con React. Es una gran librería, y seguramente la usarás en muchas de tus aplicaciones más adelante, pero es completamente innecesaria hasta que empieces a apreciar problemas de rendimiento. |
103 | 103 |
|
104 |
| -## Learning Relay, Falcor etc |
| 104 | +## Aprendiendo Relay, Falcor, etc. |
105 | 105 |
|
106 |
| -These are technologies that help you reduce the number of AJAX requests. They’re still very cutting-edge, so if you don’t have a problem with too many AJAX requests, you don’t need Relay or Falcor. |
| 106 | +Son tecnologías que te ayudan a reducir el número de peticiones AJAX. Son todavía muy innovadoras, así que si no tienes problemas con demasiadas peticiones AJAX, no necesitas Relay o Falcor. |
| 107 | + |
| 108 | +<a name="f1">1</a>: https://es.wikipedia.org/wiki/Bleeding_edge_technology |
0 commit comments