π¨ #163: React-Query, React-Forget, Rspress, Remix Vite, Next.js Barrels, Storybook, Memo, Transitions, Gluestack, VisionCamera, Unistyles, VisionOS, Expo debugging...
Hi everyone!
There's a lot of content this week! Releases, but also some very good React articles. And there's no end in sight, with some great React conferences coming up: React Advanced, Next.js Conf, reactjsday...
I've also got some great news to share with you in advance: I'm about to become the father of a little girl π€
For the 1st time ever, the newsletter will be taking a long break of several weeks, starting now. The next newsletter issue is scheduled for November 29.
Otherwise I'm staying on course to pass 30,000 subscribers by the end of the year. While I'm away, you can keep bringing me new mates π
Thank you and see you soon π
π‘ Check this newsletter on Twitter - visual format π¨
To support me:
- π Recommend the newsletter to your friends: it really helps!
- πΈ Sponsor the newsletter
- 𧡠Retweet the latest Twitter thread
Don't miss the next email!
πΈ Sponsorβ
FrontendMasters β Complete React.js Learning Path to Senior React Developer
Learn React.js from the ground up to advanced topics like performance, testing, and code quality. Start by building a real-world app in the Complete Introduction to React. Continue with Intermediate React, integrating the most popular tools from the ecosystem. Then learn performance, TypeScript, and even Next.js, the fullstack React framework!
βοΈ Reactβ
After many pre-releases, TanStack Query v5.0 stable is out, including the React Query package. In particular, it includes
- a unified, better-typed API, with no overloads
- stable Suspense support. Streaming, React Server Components (experimental)
- many other improvements: infinite queries, persistence, devtools, optimistic updates, useMutationState...
Rspress v1.0 - A fast Rspack-based static site generator
First stable release for this new static site generator from the ByteDance team. Based on Rust, React and MDX. A serious contender for Docusaurus, Nextra, Vitepress, Starlight and other content-oriented solutions. Rspress is performant, while offering an impressive list of features: i18n, versioning, search, etc. The competition is getting tough, and that's motivating me even more to add some Rust to Docusaurus π!
Remix - Vite Support (Unstable)
Remix explains its decision to become a Vite plugin in this proposal. This enables to open up its compiler and become more flexible by allowing users to add their own Vite plugins, and handle various scenarios: MDX, GraphQL, Tailwind, path aliases, etc.
π₯ Statically analysing React components for fun and profit
Sathya is working on React-Forget, the long-awaited compiler. This talk reveals some interesting details:
- Compiling is possible thanks to React's new model, which no longer uses classes or
this
- It reasons locally, is able to optimise in parallel, and can be adopted incrementally
- It works on untyped JavaScript, and understands React conventions such as hooks and the "use" prefix
- Its alias analysis system is even more complete than that of the V8 engine
Sathya says we should be hearing more about React-Forget in the coming weeks, including in the talk "Understanding Idiomatic React" at React Advanced in just 2 days. In short, we can't wait to hear more!
- πΈ Create collaborative applications like Figma and Miro in a few lines of code with Ably's in-app collaboration SDK
- π Vercel - How we optimized package imports in Next.js: explains how
optimizePackageImports
works, an option added in the latest version of Next.js to optimize the import of "Barrel files", thoseindex.js
that re-export several modules and cause performance problems. - π Unlocking the Power of Storybook: an excellent article that shares many pragmatic tips on using Storybook to iterate faster. If you have a Storybook, I strongly advise you to try visual regression tests.
- π React useTransition: performance game changer or...?: great interactive article illustrating a classic case where a React update blocks the main thread. Explains how to use transitions and concurrent rendering correctly to improve the UX.
- π React memo is good actually: interesting reflections on the use of memoization in React. One point on which I disagree: for me π¦ optimisations should be encapsulated.
- π A love letter to the Remix loader: an apology for the Remix loader, an elegant, dynamic abstraction that's easy to type. It also describes some of the challenges to be overcome.
- π Programmatic SEO in Next.js: generates Next.js pages with RSCs based on a dataset.
- π Classed Components: proposes to simplify the use of Tailwind by re-using a styled-components api and
@tw-classed/react
. - π The Rise of Next.js: Why It's the Full-Stack Framework of Choice for Modern Websites: well-documented article giving good reasons to use Next.js
- π Embedding Remix in Directus
- π Storybook - Introducing the Theme Switcher addon
- π Benchmarking MobX-State-Tree Performance
- π¦ Remix v2.1 - Experimental support for View Transitions
- π¦ Astro v3.3 - New experimental Picture component, shikiji syntax highlighting
- π¦ create-t3-app v7.22 - add Next.js App Router option
- π¦ Legend-State v2.0 - Performance, Persistence, DX improvements
- π¦ Next-international v1.1 - Improved App Router support
- π₯ Next.js Conf - 26 October - Speakers announced
- π₯ React Advanced (London π¬π§, October 20-23) is offering us -10% - code "REACT10"
Don't miss the next email!
πΈ Sponsorβ
CoderPad: Code together before you work together
Hiring front-end developers is hard. π© But 4,000+ engineering teams β including at Netflix, Spotify and LinkedIn β have found a better way! π€ Skip the algorithm interviews andΒ run front-end interviews in a fully customizable and collaborative IDEΒ - where you can:
- drag and drop a React (and Angular or Vue) repo
- add packages with npm install
- let candidates use ChatGPT live in the interview
- watch & share code playback after the interview
Use CoderPad to run fast, fair and real coding interviews that candidates and interviewers trust.Β Sign up for free today & hire with confidence.
π± React-Nativeβ
Gluestack-ui v1.0 - Universal & Accessible UI Components for React Native & Web, Unstyled & Themed
Stable v1.0 release for this new cross-platform styling solution and component library in React-Native. There's already quite a lot included in this first version: VSCode plugin, Figma kit, Expo and Next.js support, headless and styled primitives. We're going to have to take a closer look at all that! I think the RSC support with Next.js is still limited and will require the 'use client' directive.
- πΈ Moropo - build and scale open-source React Native tests 10x quicker
- π Expo - Three ways to use network debugging
- π¦ React-Native 0.72.6 - CocoaPods installs fix
- π¦ react-native-visionos: Callstack's React-Native fork, which runs React-Native on VisionOS, has been open-sourced.
- π¦ react-native-unistyles v1.0: stable version of this new cross-platform styling solution, which improves on React-Native StyleSheet DX.
- π¦ VisionCamera v3.4 - 7x faster
- π¦ React-Native-Screens v3.26 - useAnimatedHeaderHeight
- π¦ react-native-vercel-ai - cross-platform interface to Vercel AI
- π¦ radix-ui-react-native-icons
π Otherβ
- π TC39-TG4 - New Task Group created to standardize Source Maps
- π You can't get faster than No Build
- π Why Fetch Promise Doesn't Reject on Error Responses
- π DefinitelyTyped is a monorepo!
- π¦ Node.js v21 - stable fetch/WebStreams, default module system flag, V8 11.8, v20 going LTS...
- π¦ Parcel v2.10 - big performance improvements
- π¦ Oslo - A collection of auth-related utilities
- π¦ async-cache-dedupe v2
π€ Funβ
See ya! π
Don't miss the next email!