Vercel Adds Remix: Integration Supports Larger Apps
“We support 35 frameworks,” Robinson told The New Stack. “Our goal is to try to support any web framework that you want deployed on the internet. So when we were looking at our metrics, we noticed a lot of people were starting to deploy — of course, Next.js — and Remix, versus maybe the traditional Create React App-style application, which is another way of deploying your React apps.”
Vercel said the investment will allow developers to deploy and scale Remix apps of any size or complexity.
Remix: A Short History
“Both frameworks were created on top of React, but Remix tries to decouple itself from it,” Giuliani wrote last year. “We can see that Remix provides higher levels of abstraction. Also, different Remix community members have been working on different implementations using other frameworks, like Vue.js, Angular and Svelte. Next.js depends on React, and there is no plan to change this at the moment.”
Vercel’s Investment in Remix
Vercel has been working with the Remix team to improve the framework, according to Robinson.
“Our team did contribute actual upstream changes to the repository and worked with the core team there on some suggestions for where to take it in the future,” Robinson said.
One of the suggestions came from customers who used Remix. They wanted to use Vercel edge functions with the framework. Remix was designed to focus on single runtime, he said.
“It didn’t have the ability to be more granular about wanting to use different types of runtimes for different pages. So with Vercel, for example, we have serverless and edge functions — our two compute products that we offer. You can use Node.js if you want or you can use our edge product,” he said.
Vercel contributed changes and worked with the Remix team so that the core of Remix would support multiple runtimes with serverless and edge functions. Similarly, Vercel wanted Remix to be able to break down the serverless apps into multiple separate pieces, rather than one bundle, so that when it’s deployed to a provider like Vercel, each piece could use a serverless or edge function.
“If I have 1,000 routes in my application, you’re going to run into some limits if you try to put that all into one bundle,” Robinson said. “With Remix on Vercel, it can scale to thousands and thousands of routes, because it gets broken apart into these multiple bundles. For hobby developers or small or medium-sized businesses, they love that that compute is able to scale up or down and they pay for only what they use.”
Other functions supported by the integration with Vercel include:
- Streaming SSR, which allows developers to incrementally render parts of the UI to the client;
- Unlocking serverless actions;
- Stale-while-revalidating caching support, which means a request to read a value is served immediately from a cache; and
- Support for larger apps and bundles.
Vercel posted a demo of Remix running on its platform to show the integrations at work.
Robinson said one thing Remix does really well is to help developers think about and take advantage of the web platform.
“What that means in the day-to-day is, rather than having framework-specific APIs, it’s having a framework that builds on top of the web platform itself, and it uses web APIs like request, response and fetch that are portable and interchangeable between different frameworks,” Robinson said. “For developers, this is a really powerful and exciting thing because if I learned how to use the web, fetch API, I can use Next.js or Remix or Sveltekit. And once I learned this knowledge, I can kind of write it in multiple different places… The more that developers can learn pieces and have those be interoperable and shareable between different frameworks, I think is a really great outcome for the web.”