-
Notifications
You must be signed in to change notification settings - Fork 293
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 our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Translate useInsertionEffect #642
Changes from 1 commit
File filter
Filter by extension
Conversations
Jump to
Diff view
Diff view
There are no files selected for viewing
Original file line number | Diff line number | Diff line change | ||||
---|---|---|---|---|---|---|
|
@@ -4,13 +4,13 @@ title: useInsertionEffect | |||||
|
||||||
<Pitfall> | ||||||
|
||||||
`useInsertionEffect` is aimed at CSS-in-JS library authors. Unless you are working on a CSS-in-JS library and need a place to inject the styles, you probably want [`useEffect`](/reference/react/useEffect) or [`useLayoutEffect`](/reference/react/useLayoutEffect) instead. | ||||||
`useInsertionEffect` está orientado a autores de librerías CSS-in-JS. A menos que estés trabajando en una librería CSS-in-JS y necesites un lugar donde inyectar los estilos, probablemente busques [`useEffect`](/reference/react/useEffect) o [`useLayoutEffect`](/reference/react/useLayoutEffect) en su lugar. | ||||||
|
||||||
</Pitfall> | ||||||
|
||||||
<Intro> | ||||||
|
||||||
`useInsertionEffect` is a version of [`useEffect`](/reference/react/useEffect) that fires before any DOM mutations. | ||||||
`useInsertionEffect` es una versión de [`useEffect`](/reference/react/useEffect) que se dispara antes de cualquier mutación del DOM. | ||||||
|
||||||
```js | ||||||
useInsertionEffect(setup, dependencies?) | ||||||
|
@@ -22,80 +22,80 @@ useInsertionEffect(setup, dependencies?) | |||||
|
||||||
--- | ||||||
|
||||||
## Reference {/*reference*/} | ||||||
## Referencia {/*reference*/} | ||||||
|
||||||
### `useInsertionEffect(setup, dependencies?)` {/*useinsertioneffect*/} | ||||||
|
||||||
Call `useInsertionEffect` to insert the styles before any DOM mutations: | ||||||
Llama a `useInsertionEffect` para insertar los estilos antes de cualquier mutación en el DOM: | ||||||
|
||||||
```js | ||||||
import { useInsertionEffect } from 'react'; | ||||||
|
||||||
// Inside your CSS-in-JS library | ||||||
// En tu librería CSS-in-JS | ||||||
function useCSS(rule) { | ||||||
useInsertionEffect(() => { | ||||||
// ... inject <style> tags here ... | ||||||
// ... inyecta las etiquetas <style> aquí ... | ||||||
}); | ||||||
return rule; | ||||||
} | ||||||
``` | ||||||
|
||||||
[See more examples below.](#usage) | ||||||
[Ver más ejemplos a continuación.](#usage) | ||||||
|
||||||
#### Parameters {/*parameters*/} | ||||||
#### Parámetros {/*parameters*/} | ||||||
|
||||||
* `setup`: The function with your Effect's logic. Your setup function may also optionally return a *cleanup* function. Before your component is first added to the DOM, React will run your setup function. After every re-render with changed dependencies, React will first run the cleanup function (if you provided it) with the old values, and then run your setup function with the new values. Before your component is removed from the DOM, React will run your cleanup function one last time. | ||||||
|
||||||
* **optional** `dependencies`: The list of all reactive values referenced inside of the `setup` code. Reactive values include props, state, and all the variables and functions declared directly inside your component body. If your linter is [configured for React](/learn/editor-setup#linting), it will verify that every reactive value is correctly specified as a dependency. The list of dependencies must have a constant number of items and be written inline like `[dep1, dep2, dep3]`. React will compare each dependency with its previous value using the [`Object.is`](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Object/is) comparison algorithm. If you don't specify the dependencies at all, your Effect will re-run after every re-render of the component. | ||||||
* `setup`: La función con la lógica de tu Effect. Tu función setup puede opcionalmente devolver una función de *limpieza*. Antes de que tu componente sea añadido primero al DOM, React ejecutará tu función setup. Después de cada re-renderizado con dependencias modificadas, React ejecutará primero la función de limpieza (si es que la habías incluido) con los valores antiguos y entonces ejecutará tu función setup con los nuevos valores. Antes de que tu componente sea eliminado del DOM, React ejecutará tu función de limpieza una última vez. | ||||||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Effect lo hemos traducido como Efecto en las demás páginas, respetando el uso de mayúsculas del original.
Suggested change
|
||||||
|
||||||
#### Returns {/*returns*/} | ||||||
* **opcional** `dependencias`: La lista de todos los valores reactivos referenciados dentro del el código de `setup`. Los valores reactivos incluyen props, estado y todas las variables y funciones declaradas directamente dentro del cuerpo de tu componente. Si tu linter está [configurado para React](/learn/editor-setup#linting), verificará que cada valor reactivo esté correctamente especificado como dependencia. La lista de dependencias tienen que tener un número constante de elementos y que sean escritos en línea como `[dep1, dep2, dep3]`. React comparará cada dependencia con su valor previo usando el algoritmo de comparación [`Object.is`](https://developer.mozilla.org/es/docs/Web/JavaScript/Reference/Global_Objects/Object/is). Si no especificas ninguna dependencia, tu Effect se re-ejecutará después de cada re-renderizado del componente. | ||||||
|
||||||
`useInsertionEffect` returns `undefined`. | ||||||
#### Retorno {/*returns*/} | ||||||
|
||||||
#### Caveats {/*caveats*/} | ||||||
`useInsertionEffect` devuelve `undefined`. | ||||||
|
||||||
* Effects only run on the client. They don't run during server rendering. | ||||||
* You can't update state from inside `useInsertionEffect`. | ||||||
* By the time `useInsertionEffect` runs, refs are not attached yet, and DOM is not yet updated. | ||||||
#### Advertencias {/*caveats*/} | ||||||
|
||||||
* Effect que sólo se ejecuta en el cliente. No se ejecutan durante el renderizado en el servidor. | ||||||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more.
Suggested change
|
||||||
* No puedes actualizar el estado dentro de `useInsertionEffect`. | ||||||
* En el tiempo en que `useInsertionEffect` se ejecuta, las referencias aún no han sido acopladas y el DOM todavía no ha sido actualizado. | ||||||
|
||||||
--- | ||||||
|
||||||
## Usage {/*usage*/} | ||||||
## Uso {/*usage*/} | ||||||
|
||||||
### Injecting dynamic styles from CSS-in-JS libraries {/*injecting-dynamic-styles-from-css-in-js-libraries*/} | ||||||
### Inyectando estilos dinámicos desde librerías CSS-in-JS {/*injecting-dynamic-styles-from-css-in-js-libraries*/} | ||||||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. https://github.com/reactjs/es.reactjs.org/blob/main/TRANSLATION.md#el-gerundio
Suggested change
|
||||||
|
||||||
Traditionally, you would style React components using plain CSS. | ||||||
Tradicionalmente, añadirías estilo a los componentes de React usando CSS plano. | ||||||
|
||||||
```js | ||||||
// In your JS file: | ||||||
// En tu archivo JS: | ||||||
<button className="success" /> | ||||||
|
||||||
// In your CSS file: | ||||||
// En tu archivo CSS: | ||||||
.success { color: green; } | ||||||
``` | ||||||
|
||||||
Some teams prefer to author styles directly in JavaScript code instead of writing CSS files. This usually requires using a CSS-in-JS library or a tool. There are three common approaches to CSS-in-JS you might encounter: | ||||||
Algunos equipos prefieren incluir sus estilos directamente en el código JavaScript en lugar de escribir archivos CSS. Esto normalmente requiere usar una librería CSS-in-JS o una herramienta. Existen tres formas comunes de plantear el CSS-in-JS que puedes encontrar: | ||||||
|
||||||
1. Static extraction to CSS files with a compiler | ||||||
2. Inline styles, e.g. `<div style={{ opacity: 1 }}>` | ||||||
3. Runtime injection of `<style>` tags | ||||||
1. Extracción estática de archivos CSS con un compilador | ||||||
2. Estilos en línea, ej. `<div style={{ opacity: 1 }}>` | ||||||
3. Inyección durante el runtime de las etiquetas `<style>` | ||||||
|
||||||
If you use CSS-in-JS, we recommend a combination of the first two approaches (CSS files for static styles, inline styles for dynamic styles). **We don't recommend runtime `<style>` tag injection for two reasons:** | ||||||
Si usas CSS-in-JS, recomendamos la combinación de los dos primeros enfoques (archivos CSS para estilos estáticos, estilos en línea para estilos dinámicos). **No recomendamos la inyección durante el runtime de la etiqueta `<style>` por dos razones:** | ||||||
|
||||||
1. Runtime injection forces the browser to recalculate the styles a lot more often. | ||||||
2. Runtime injection can be very slow if it happens at the wrong time in the React lifecycle. | ||||||
1. La inyección durante el runtime fuerza al navegador a recalcular los estilos mucho más a menudo. | ||||||
2. La inyección durante el runtime puede ser muy lenta si ocurre en un tiempo inadecuado en el ciclo de vida de React. | ||||||
|
||||||
The first problem is not solvable, but `useInsertionEffect` helps you solve the second problem. | ||||||
El primer problema no es solucionable pero `useInsertionEffect` te ayuda a resolver el segundo problema. | ||||||
|
||||||
Call `useInsertionEffect` to insert the styles before any DOM mutations: | ||||||
Llama a `useInsertionEffect` para insertar los estilos antes de cualquier mutación del DOM: | ||||||
|
||||||
```js {4-11} | ||||||
// Inside your CSS-in-JS library | ||||||
// En tu librería CSS-in-JS | ||||||
let isInserted = new Set(); | ||||||
function useCSS(rule) { | ||||||
useInsertionEffect(() => { | ||||||
// As explained earlier, we don't recommend runtime injection of <style> tags. | ||||||
// But if you have to do it, then it's important to do in useInsertionEffect. | ||||||
// Como hemos explicado antes, no recomendamos la inyección durante el runtime de las etiquetas <style>. | ||||||
// Pero si tienes que hacerlo, entonces es importante que sea dentro del useInsertionEffect. | ||||||
if (!isInserted.has(rule)) { | ||||||
isInserted.add(rule); | ||||||
document.head.appendChild(getStyleForRule(rule)); | ||||||
|
@@ -110,7 +110,7 @@ function Button() { | |||||
} | ||||||
``` | ||||||
|
||||||
Similarly to `useEffect`, `useInsertionEffect` does not run on the server. If you need to collect which CSS rules have been used on the server, you can do it during rendering: | ||||||
De forma similar a `useEffect`, `useInsertionEffect` no se ejecuta en el servidor. Si tienes que agrupar las reglas CSS has usado en el servidor, puedes hacerlo durante el renderizado: | ||||||
|
||||||
```js {1,4-6} | ||||||
let collectedRulesSet = new Set(); | ||||||
|
@@ -126,14 +126,14 @@ function useCSS(rule) { | |||||
} | ||||||
``` | ||||||
|
||||||
[Read more about upgrading CSS-in-JS libraries with runtime injection to `useInsertionEffect`.](https://github.com/reactwg/react-18/discussions/110) | ||||||
[Lee más sobre actualizar librerías CSS-in-JS con la inyección en runtime `useInsertionEffect`.](https://github.com/reactwg/react-18/discussions/110) | ||||||
|
||||||
<DeepDive> | ||||||
|
||||||
#### How is this better than injecting styles during rendering or useLayoutEffect? {/*how-is-this-better-than-injecting-styles-during-rendering-or-uselayouteffect*/} | ||||||
#### ¿Cómo puede ser esto mejor que inyectar estilos durante el renderizado o useLayoutEffect? {/*how-is-this-better-than-injecting-styles-during-rendering-or-uselayouteffect*/} | ||||||
|
||||||
If you insert styles during rendering and React is processing a [non-blocking update,](/reference/react/useTransition#marking-a-state-update-as-a-non-blocking-transition) the browser will recalculate the styles every single frame while rendering a component tree, which can be **extremely slow.** | ||||||
Si insertas los estilos durante el renderizado y React está procesando una [actualización no bloqueante,](/reference/react/useTransition#marking-a-state-update-as-a-non-blocking-transition) el navegador recalculará los estilos en cada frame mientras renderiza un árbol de componentes, lo que puede ser **extremadamente lento.** | ||||||
|
||||||
`useInsertionEffect` is better than inserting styles during [`useLayoutEffect`](/reference/react/useLayoutEffect) or [`useEffect`](/reference/react/useEffect) because it ensures that by the time other Effects run in your components, the `<style>` tags have already been inserted. Otherwise, layout calculations in regular Effects would be wrong due to outdated styles. | ||||||
`useInsertionEffect` es mejor que insertar estilos durante [`useLayoutEffect`](/reference/react/useLayoutEffect) o [`useEffect`](/reference/react/useEffect) porque asegura que en el tiempo en que otros Efectos se ejecuten en tus componentes, las etiquetas `<style>` ya han sido añadidas. De otro modo, los cálculos de layout en Effects regulares podrían ser incorrectos por los estilos desactualizados. | ||||||
|
||||||
</DeepDive> |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
(Esto aplica a otras partes del documento en que se repiten estas situaciones).