Ponte tus gorras de pensamiento con Suspense y Concurrent mode! En esta charla, discutiré cómo mejorar la experiencia de usuario existente con la magia de Suspense y Concurrent mode de React para renderizado no bloqueado. La charla destacará las mejores prácticas y pautas para lo mismo.
This talk has been presented at React Summit Remote Edition 2021, check out the latest edition of this React Conference.
FAQ
React Suspense es una función de React que permite controlar la renderización de componentes de manera asíncrona, mejorando la experiencia del usuario al gestionar de forma más eficiente los estados de carga en la interfaz.
El modo concurrente en React permite una mejor gestión de las tareas prioritarias y la carga de datos en paralelo, lo que mejora la interactividad y reduce los tiempos de espera en la interfaz de usuario.
React Suspense permite definir límites en la interfaz de usuario donde se puede controlar la aparición de indicadores de carga, facilitando una experiencia más fluida y menos intrusiva para el usuario.
useTransition es un hook en React que permite gestionar transiciones de estado con suavidad. Se utiliza para evitar la visualización de indicadores de carga innecesarios cuando la carga de datos es muy rápida.
React Suspense y el modo concurrente aún se consideran características experimentales y pueden contener errores. Es recomendable usarlos en proyectos personales y evitar su implementación en entornos empresariales hasta que estén más establecidos.
Puedes seguir a Nikhil en Twitter y Github para obtener más información sobre sus proyectos y contribuciones en Postman, y visitar el sitio web de carreras de Postman para oportunidades de colaboración y empleo.
Esta charla explora cómo React Suspense y Concurrent mode pueden mejorar la experiencia de usuario al controlar áreas de carga, precargar datos y reducir el tiempo de carga. Demuestra cómo UseTransition puede eliminar cargadores innecesarios al omitir el estado de carga si los datos llegan en un tiempo especificado. El orador recomienda utilizar estas características experimentales en proyectos personales en lugar de aplicaciones empresariales. La charla concluye con una invitación a unirse al viaje en Postman y agradece a los organizadores, patrocinadores, oradores y audiencia por hacer de la conferencia un éxito.
1. Introduction to React Suspense and Concurrent Mode
Short description:
En esta charla, discutiremos cómo llevar la experiencia de usuario al siguiente nivel con React Suspense y el modo Concurrente. Cubriremos el control de la zona de carga, la precarga de datos y la reducción del tiempo de carga. También exploraremos cómo el modo concurrente puede eliminar cargadores innecesarios. Se utilizará una demostración de un panel de Twitter para mostrar estos conceptos.
¡Hola a todos! Hoy voy a hablar sobre cómo podemos llevar la experiencia de usuario al siguiente nivel con React Suspense y el modo Concurrente. Antes de comenzar, para aquellos que no me conocen, soy Nikhil, ingeniero de software en Postman. Me encargo de cosas relacionadas con los sistemas de diseño, Postman en la web y Postman como plataforma. Pueden encontrarme en Twitter y en Github. Me encanta hablar sobre sistemas de diseño y rendimiento en general, así que vengan a saludar, será una gran charla.
Antes de profundizar, cubramos cuáles serán los puntos clave de esta charla relámpago. En esta charla, discutiremos cómo tener un mayor control sobre la zona de carga, es decir, cómo controlar dónde queremos mostrar una forma de carga. ¿Será toda la página o podemos controlar la carga en la interfaz de usuario de forma asíncrona con la API llamada Suspense? En segundo lugar, veremos cómo podemos comenzar a precargar nuestros datos o nuestras pantallas en segundo plano mientras estamos en otra pantalla con la magia del modo concurrente. Y en tercer lugar, veremos cómo podemos reducir la experiencia de carga molesta que los usuarios con conexiones más rápidas experimentan con un indicador de carga que aparece y desaparece rápidamente utilizando un hook llamado useTransition. Con eso dicho, sumerjámonos en este camino hacia una gran experiencia de usuario. Cambiaré a una pequeña demostración de un panel de Twitter que tengo aquí, ¿de acuerdo? Este panel me muestra una sección de perfil donde se muestra mi nombre, mi cargo, una pequeña descripción sobre mí y el trabajo que he realizado. También hay una sección de tweets que muestra el último tweet que publiqué. No intenten buscarlo en Twitter, es algo que no pude escribir. Y hay un botón adicional que puedo hacer clic para ver otro tweet. Hasta ahora todo bien. Ahora, permítanme cambiar al modo concurrente de esta aplicación y ver cómo podemos mejorar la experiencia de usuario. Refrescaré la página y iré a la sección 'sobre mí'. Si lo ven, tengo un gran indicador de carga en toda la pestaña. Aunque solo tengo un pequeño contenido dentro de mi pestaña, que es mi descripción, que se carga de forma asíncrona, estoy cargando toda la pestaña y mostrando una pantalla de carga para toda esta sección, lo cual no es una gran experiencia de usuario. Podría renderizar mi contenido estático independientemente de si mi descripción se está cargando o no. Pasemos a cómo está codificado actualmente. Veamos cómo hemos escrito esto en nuestro código. Tenemos un bloque de suspense y dentro de este bloque, tenemos algún contenido estático en un pequeño div. ¿Qué pasaría si pudiera sacar este div en particular y renderizarlo fuera del bloque de suspense? Así es como Suspense te brinda un control detallado al definir un pequeño límite y te permite controlar qué quieres mostrar mientras se está cargando. Por ejemplo, si refresco esta aplicación y voy a la sección 'sobre mí', mi contenido estático ya está ahí para que mis usuarios interactúen mientras se carga mi descripción. Hasta ahora todo bien y es sencillo. Ahora intentemos descubrir cómo el modo concurrente puede ayudarnos a eliminar algunos de esos cargadores adicionales. En el lado izquierdo, tenemos una versión síncrona de esa aplicación. Y actualmente, obtenemos los datos mientras vamos a una pantalla. En el lado izquierdo, hago clic en la sección 'sobre mí', veo un buen indicador de carga y luego comienzo a cargar esos datos. Pero como el modo concurrente es algo que cambia las tareas según su prioridad, puedo comenzar a obtener mi descripción y mis tweets cuando estoy en la página de perfil y puedo comenzar a renderizar cosas en paralelo mientras estoy en este perfil. ¿Qué creen que sucedería si simplemente voy a la sección 'sobre mí' y hago clic en esto?
Entonces hago clic en una sección de tweets y comienza a buscar datos en segundo plano. El cargador que aparece al hacer clic en el botón de siguiente tweet es innecesario para los usuarios con conexiones más rápidas. Podemos eliminar el cargador utilizando UseTransition y un tiempo de espera. Esto permite que React omita el estado de carga si los datos llegan dentro de un tiempo especificado. Al utilizar la función de transición de inicio, podemos manejar el estado de carga y utilizar el valor de gasto proporcionado por UseTransition. Esto nos permite omitir el estado de carga en el modo concurrente síncrono y mostrar el tweet al instante.
vería un cargador? Vamos a descubrirlo. Así que hago clic en esto, no hay cargador, no hay spinner, parece que en realidad estaba ahí ahora mismo, ¿verdad? Hago clic en esta sección de tweets, pero en este lado izquierdo, hago clic en esto y ahora comienza a buscar cosas mientras estoy ahora en el stream, ¿verdad? Bien, ahora se han mitigado dos spinners. Bien, ahora vamos a descubrir otro caso de uso. ¿Qué sucede cuando hago clic en este botón de siguiente tweet? En realidad veo un cargador y simplemente aparece y desaparece, ¿verdad? Lo veo en un instante. Y esto es algo que enfrentan nuestros usuarios con conexiones más rápidas, ¿verdad? Y el propósito de este cargador no se cumple porque los pequeños milisegundos de tiempo serían algo que realmente omitiría ese estado de carga, ¿verdad? Y en realidad dejaría que tu stream sea como es en lugar de mostrar el cargador. Ahora, vamos a intentar eliminar este cargador en sí y usar un código llamado UseTransition. Así que tengo este componente aquí, que es TweetList y voy a comentar esta línea, que se llama UseTransition. Y lo que me pide es que le dé un tiempo de espera en milisegundos. Ahora, lo que esto realmente significa es que React omitirá mi estado de carga si mis data realmente llega dentro de estos dos segundos de tiempo. Así que si reviso esta lógica onclick de mi botón, ¿verdad? Esta es en realidad la lógica donde establezco mi estado y habilito el estado de carga con suspense. Ahora, ¿qué pasaría si pudiera tomar todo esto, copiarlo y usar start transition que en realidad tiene una función y pegar todo eso dentro. Bien. Y la función de inicio se encarga de todo lo que si los data realmente llegan dentro de estos dos segundos de tiempo solo para el estado de carga. Ahora vamos a usar este valor de gasto que nos da use transition. Así que deshabilitemos este botón para ver esto. Guardo. Ahora veamos cómo suceden las cosas en el modo concurrente síncrono. ¿De acuerdo? Así que hago clic en esta sección de tweets. Ahora estoy viendo una hoja de carga por primera vez. Hago clic en este botón. Es modo síncrono y ahora estoy viendo un cargador que no es realmente bueno. Así que veamos qué sucede cuando cambio a modo concurrente. Así que con ese gancho de transición enorme, ahora puedo omitir ese estado de carga. ¿De acuerdo? Así que hago clic en este siguiente tweet. No veo un cargador. Solo se queda como está. Y luego el tweet aparece en un instante. Vamos a ver una vez más. Hago clic en esto, no hay cargador y el tweet aparece
3. Conclusion and Acknowledgements
Short description:
Y parecía que todo sucedió en un instante. Hemos logrado un buen progreso en términos de experiencia de usuario. Sin embargo, el suspense y el modo concurrente aún son experimentales, por lo que es recomendable utilizarlos en proyectos personales en lugar de aplicaciones empresariales. Por cierto, estamos construyendo grandes cosas en Postman y te invitamos a unirte a nuestro viaje. Gracias a los organizadores, patrocinadores, ponentes y audiencia por hacer de esta conferencia un éxito.
como un destello. Y parecía que todo sucedió en un instante. Bien. De acuerdo. Hasta ahora todo va bien. Y creo que hemos logrado un buen progreso en términos de una buena experiencia de usuario. Hasta ahora todo va bien. Ustedes son increíbles. Ahora todos podrían estar tentados a pensar que, hey, esta es una API súper genial y déjame usar el suspense y el modo concurrente y decirles a mis gerentes y líderes técnicos, hey, usemos esta API. Es increíble. Y esto es algo que en realidad Facebook y React mismo podrían no estar a favor en este momento porque el suspense o la obtención de datos y el modo concurrente son algo que en este momento son experimentales. Y el equipo de Facebook todavía está buscando más comentarios ya que se espera que la API siga evolucionando y puede tener errores en este momento ya que es experimental. Entonces, es posible que realmente desee jugar con estas API en sus proyectos personales, pero pensar en algo que sea empresarial no es algo que realmente desee hacer, ¿verdad? Ya que las cosas pueden tener errores. De acuerdo. Por cierto, estamos construyendo grandes cosas en Postman. Entonces, si realmente te gustaría ser parte de nuestro viaje, por favor ven y saluda y visítanos en nuestro sitio web de carreras. Nos gustaría conectarnos y discutir las cosas en el futuro. Con esto, me gustaría terminar mi charla. Un gran agradecimiento a todos los organizadores y patrocinadores que están trabajando arduamente para hacer de esta conferencia un gran éxito y a todos los ponentes y, por último pero no menos importante, a la audiencia. Ustedes, ustedes son geniales al tener una gran discusión con todos ustedes. Muchas gracias.
This transcription provides a brief guide to React rendering behavior. It explains the process of rendering, comparing new and old elements, and the importance of pure rendering without side effects. It also covers topics such as batching and double rendering, optimizing rendering and using context and Redux in React. Overall, it offers valuable insights for developers looking to understand and optimize React rendering.
Remix is a web framework built on React Router that focuses on web fundamentals, accessibility, performance, and flexibility. It delivers real HTML and SEO benefits, and allows for automatic updating of meta tags and styles. It provides features like login functionality, session management, and error handling. Remix is a server-rendered framework that can enhance sites with JavaScript but doesn't require it for basic functionality. It aims to create quality HTML-driven documents and is flexible for use with different web technologies and stacks.
The Talk discusses React Forget, a compiler built at Meta that aims to optimize client-side React development. It explores the use of memoization to improve performance and the vision of Forget to automatically determine dependencies at build time. Forget is named with an F-word pun and has the potential to optimize server builds and enable dead code elimination. The team plans to make Forget open-source and is focused on ensuring its quality before release.
Today's Talk explores the use of the useEffect hook in React development, covering topics such as fetching data, handling race conditions and cleanup, and optimizing performance. It also discusses the correct use of useEffect in React 18, the distinction between Activity Effects and Action Effects, and the potential misuse of useEffect. The Talk highlights the benefits of using useQuery or SWR for data fetching, the problems with using useEffect for initializing global singletons, and the use of state machines for handling effects. The speaker also recommends exploring the beta React docs and using tools like the stately.ai editor for visualizing state machines.
Routing in React 18 brings a native app-like user experience and allows applications to transition between different environments. React Router and Next.js have different approaches to routing, with React Router using component-based routing and Next.js using file system-based routing. React server components provide the primitives to address the disadvantages of multipage applications while maintaining the same user experience. Improving navigation and routing in React involves including loading UI, pre-rendering parts of the screen, and using server components for more performant experiences. Next.js and Remix are moving towards a converging solution by combining component-based routing with file system routing.
This Talk is about interactive data visualization in React using the Plot library. Plot is a high-level library that simplifies the process of visualizing data by providing key concepts and defaults for layout decisions. It can be integrated with React using hooks like useRef and useEffect. Plot allows for customization and supports features like sorting and adding additional marks. The Talk also discusses accessibility concerns, SSR support, and compares Plot to other libraries like D3 and Vega-Lite.
Los primeros intentos de Ivan en la depuración de rendimiento fueron caóticos. Vería una interacción lenta, intentaría una optimización aleatoria, vería que no ayudaba, y seguiría intentando otras optimizaciones hasta que encontraba la correcta (o se rendía). En aquel entonces, Ivan no sabía cómo usar bien las herramientas de rendimiento. Haría una grabación en Chrome DevTools o React Profiler, la examinaría, intentaría hacer clic en cosas aleatorias, y luego la cerraría frustrado unos minutos después. Ahora, Ivan sabe exactamente dónde y qué buscar. Y en esta masterclass, Ivan te enseñará eso también. Así es como va a funcionar. Tomaremos una aplicación lenta → la depuraremos (usando herramientas como Chrome DevTools, React Profiler, y why-did-you-render) → identificaremos el cuello de botella → y luego repetiremos, varias veces más. No hablaremos de las soluciones (en el 90% de los casos, es simplemente el viejo y regular useMemo() o memo()). Pero hablaremos de todo lo que viene antes - y aprenderemos a analizar cualquier problema de rendimiento de React, paso a paso. (Nota: Esta masterclass es más adecuada para ingenieros que ya están familiarizados con cómo funcionan useMemo() y memo() - pero quieren mejorar en el uso de las herramientas de rendimiento alrededor de React. Además, estaremos cubriendo el rendimiento de la interacción, no la velocidad de carga, por lo que no escucharás una palabra sobre Lighthouse 🤐)
Con el lanzamiento de React 18 finalmente obtenemos el tan esperado renderizado concurrente. Pero, ¿cómo va a afectar eso a tu aplicación? ¿Cuáles son los beneficios del renderizado concurrente en React? ¿Qué necesitas hacer para cambiar al renderizado concurrente cuando actualices a React 18? ¿Y qué pasa si no quieres o no puedes usar el renderizado concurrente todavía?
¡Hay algunos cambios de comportamiento de los que debes estar al tanto! En esta masterclass cubriremos todos esos temas y más.
Acompáñame con tu portátil en esta masterclass interactiva. Verás lo fácil que es cambiar al renderizado concurrente en tu aplicación React. Aprenderás todo sobre el renderizado concurrente, SuspenseList, la API startTransition y más.
La adición de la API de hooks a React fue un cambio bastante importante. Antes de los hooks, la mayoría de los componentos tenían que ser basados en clases. Ahora, con los hooks, estos son a menudo componentes funcionales mucho más simples. Los hooks pueden ser realmente simples de usar. Casi engañosamente simples. Porque todavía hay muchas formas en las que puedes equivocarte con los hooks. Y a menudo resulta que hay muchas formas en las que puedes mejorar tus componentes con una mejor comprensión de cómo se puede usar cada hook de React.Aprenderás todo sobre los pros y los contras de los diversos hooks. Aprenderás cuándo usar useState() versus useReducer(). Veremos cómo usar useContext() de manera eficiente. Verás cuándo usar useLayoutEffect() y cuándo useEffect() es mejor.
ReactJS es extremadamente popular y, por lo tanto, ampliamente soportado. TypeScript está ganando popularidad y, por lo tanto, cada vez más soportado.
¿Los dos juntos? No tanto. Dado que ambos cambian rápidamente, es difícil encontrar materiales de aprendizaje precisos.
¿React+TypeScript, con los IDEs de JetBrains? Esa combinación de tres partes es el tema de esta serie. Mostraremos un poco sobre mucho. Es decir, los pasos clave para ser productivo, en el IDE, para proyectos de React utilizando TypeScript. En el camino, mostraremos el desarrollo guiado por pruebas y enfatizaremos consejos y trucos en el IDE.
En esta masterclass, aprenderás cómo construir tu primer dapp de pila completa en la blockchain de Ethereum, leyendo y escribiendo datos en la red, y conectando una aplicación de front end al contrato que has desplegado. Al final de la masterclass, entenderás cómo configurar un entorno de desarrollo de pila completa, ejecutar un nodo local e interactuar con cualquier contrato inteligente usando React, HardHat y Ethers.js.
La Biblioteca de Pruebas de React es un gran marco para las pruebas de componentes de React porque responde muchas preguntas por ti, por lo que no necesitas preocuparte por esas preguntas. Pero eso no significa que las pruebas sean fáciles. Todavía hay muchas preguntas que tienes que resolver por ti mismo: ¿Cuántas pruebas de componentes debes escribir vs pruebas de extremo a extremo o pruebas de unidad de nivel inferior? ¿Cómo puedes probar una cierta línea de código que es difícil de probar? ¿Y qué se supone que debes hacer con esa persistente advertencia de act()? En esta masterclass de tres horas, presentaremos la Biblioteca de Pruebas de React junto con un modelo mental de cómo pensar en el diseño de tus pruebas de componentes. Este modelo mental te ayudará a ver cómo probar cada bit de lógica, si debes o no simular dependencias, y ayudará a mejorar el diseño de tus componentes. Te irás con las herramientas, técnicas y principios que necesitas para implementar pruebas de componentes de bajo costo y alto valor. Tabla de contenidos- Los diferentes tipos de pruebas de aplicaciones de React, y dónde encajan las pruebas de componentes- Un modelo mental para pensar en las entradas y salidas de los componentes que pruebas- Opciones para seleccionar elementos DOM para verificar e interactuar con ellos- El valor de los mocks y por qué no deben evitarse- Los desafíos con la asincronía en las pruebas de RTL y cómo manejarlos Requisitos previos- Familiaridad con la construcción de aplicaciones con React- Experiencia básica escribiendo pruebas automatizadas con Jest u otro marco de pruebas unitarias- No necesitas ninguna experiencia con la Biblioteca de Pruebas de React- Configuración de la máquina: Node LTS, Yarn
Comments