Skip to main content
What is Vite? & Vite vs Webpack
9 min read

What is Vite? & Vite vs Webpack

Introduction

We'll talk about the history of vite and the importance of using Vite, we'll also deep dive into developer experience with Vite and why you want to start using Vite.

In this section, we'll be talking about ES modules and the evolution of bundling Javascript code. In the ever-evolving landscape of web development, speed and efficiency are crucial factors that can make or break a project. As developers, we constantly seek tools that can streamline our workflow and deliver optimal performance.

The problem of bundling has been as old as developers finding a way to organize their code in a modular fashion. ES modules which became a solution to the problem, allowed developers to have a better developer experience by allowing code to be grouped by modules and allowing module variables to be accessible to other modules if need be.

Using ES module specifications or webpack, which allowed ESM for unsupported browsers, soon began to pose a problem. As developers build large-scale applications, there are thousands of modules these large applications depend on, making the building process extremely slow and a pain for developers.

It is this very problem that has brought about the creation of Vite!. Vite.js was created by Evan You the creator of Vue.js, a very popular Javascript framework. Vite was created as a way to both simplify and speed up the frontend development build cycle.

Steps we'll cover:

What is Vite.js?

Javascript build tools can be a pain to developers, especially when all you want to do is focus on development. Developers want a simplified way of building and developing their applications and Vite.js is one of the popular tools that solves this problem. We'll be talking about Vite.js and its key features in this tutorial.

We'll talk about how Vite was built fundamentally and how it addresses performance challenges in web development. Fundamentally, at the core, Vite.js does two main things, and does it really well:

  1. Serve code locally during development
  2. Bundle all your frontend assets (HTML, CSS, JS etc.) for production.

Vite leverages native ES modules in the browser. This will help to load your code instantly, no matter how large your module dependencies are or how large the application code has become. Vite also uses Hot Module Replacement (HMR). HMR accounts for the fast and effective part of Vite, as it watches for state changes in the application and adds and/or removes modules while the application is running without prompting a full reload of the application. What this means for the developers is you can see the changes you make to your code instantly right in your browser as you're coding. Cool right?!.

How does Vite.js Address Performance Challenges?

In this section, let's take a look at how Vite addresses some of the performance challenges in front-end web development.

  1. Native ES Modules Support: Vite.js fully embraces native ES modules. Native ES modules are supported in modern browsers. Instead of bundling modules during development, Vite.js leverages the native capabilities of browsers to directly load ES modules as separate files. This adoption eliminates the need for bundling and enables faster startup times and better cacheability. It also ensures that the browser results in improved overall performance.
  2. Blazing-Fast Build Process: Vite.js leverages the "esbuild" bundler, known for its exceptional speed. During the production build process, Vite.js uses "esbuild" to generate optimized and minified code bundles. The "esbuild" rapid bundling capabilities significantly reduces build times compared to traditional bundlers. This leads to improved and faster deployment and developer productivity.
  3. Code Splitting and Lazy Loading: Vite.js supports code splitting and lazy loading out of the box. By breaking down the codebase into smaller chunks, Vite.js enables more efficient loading and execution of JavaScript. Only the necessary modules are loaded when required, reducing initial load times and improving performance. Lazy loading allows developers to load specific parts of an application on-demand, further optimizing the loading process and improving the user experience.

Key Features of Vite

In this section, we'll be talking about the key features Vite has to offer and why you should get started using it. Vite.js, being a modern front-end development build tool, offers several key features that differentiate it from traditional bundlers. Here are some of the features:

  1. Lightning-Fast Development Server: Vite.js introduces a highly optimized development server that leverages native ES module imports in modern browsers. It employs an on-demand compilation approach, allowing for near-instantaneous hot module replacement (HMR) and rapid page reloads. This significantly speeds up the development workflow, providing faster feedback loops and enhancing developer productivity.
  2. Native ES Modules Support: Vite.js fully embraces native ES modules, which are natively supported in modern browsers. During development, Vite.js leverages the browser's ability to load ES modules as separate files without the need for bundling. This approach eliminates the overhead of bundling during development, resulting in faster startup times and better cacheability. It also allows the browser to parallelize module loading, leading to improved overall performance.
  3. Blazing-Fast Production Builds: Vite.js utilizes the "esbuild" bundler, known for its exceptional speed, during the production build process. "esbuild" generates optimized and minified code bundles, resulting in significantly reduced build times compared to traditional bundlers. This swift bundling process enhances developer efficiency and allows for faster deployment cycles.
  4. Zero Configuration: Vite.js follows a zero-configuration philosophy, providing a seamless out-of-the-box experience. By minimizing the need for manual configuration, developers can quickly set up new projects without spending time on complex configuration setups. However, Vite.js also offers a flexible configuration file (vite.config.js) for advanced customization when needed.
  5. Devtool Integration: Vite.js seamlessly integrates with popular browser developer tools. It provides an enhanced debugging experience by mapping original source code to the browser, enabling developers to directly debug their code without any additional setup or tooling.
  6. Plugin Ecosystem: Vite.js has a growing ecosystem of plugins that extend its functionality and integrate with popular frontend frameworks like Vue.js, React, and Preact. These plugins enhance the development experience and offer additional features, optimizations, and integrations with tools and libraries.

Vite vs Webpack

In this section, we'll be doing a comparison between Vite and Webpack. There are similar bundling tools like webpack for example Rollup and Parcel. The major difference between these tools is Vite uses a native ES module dev server, while webpack uses a bundle based dev server. Below is a picture of how modules are bundled with native ESM:


vite vs webpack

With this setup, unnecessary bundling during development is avoided and build time is greatly reduced and significantly faster

Here is an image of a typical webpack dev server:


vite vs webpack

Vite.js follows a simplified and opinionated configuration approach. The configuration file is minimal, making it easier to set up and get started quickly.
Vite.js has a growing ecosystem of plugins that integrate seamlessly with popular frontend frameworks such as Vue.js, React, and Preact, while webpack is known for its extensive configuration options, allowing developers to fine-tune every aspect of the bundling process. Its vast ecosystem provides a wide range of plugins and loaders, making it highly versatile and adaptable to different project requirements.

Here is an image of a time benchmark test between webpack and Vite:


vite vs webpack

From the image we can see how fast Vite is in comparison to webpack.

Migrating from Vite to Webpack

In this section we'll look at how we can migrate our application using webpack to Vite. Here are some steps and things to note:

  • First install Vite and all its plugins. You can check the getting started guide here
  • Make sure your project is using ES modules. You can do that by going to your package.json file and pasting
"type": "module",
  • Remove all webpack configuration files, like webpack.config.js, and replace it with a vite.config.js file. Also in your scripts, you'll need to update with this:
"build": "vite build", 
"dev": "vite serve",
  • Make sure to remove webpack loaders and plugins that are no longer in use and test your application, so everything is working as it should

Using Vite.js in practice

In this section, we will talk about how we can get started using Vite in practice and also demonstrate with some example code.

To scaffold a react project with vite, paste:

# npm 6.x
npm create vite@latest my-react-app --template react

# npm 7+, extra double-dash is needed:
npm create vite@latest my-react-app -- --template react

You can now change into the project directory, run npm install and start our development server.

cd react-vite
npm install
npm run dev

In the scripts file we have our commands for building for production and creating a local preview.

{
"scripts": {
"dev": "vite", // start dev server, aliases: `vite dev`, `vite serve`
"build": "vite build", // build for production
"preview": "vite preview"// locally preview production build
}
}

discord banner

Conclusion

Finally, we have come to the end of the tutorial, and we have been able to learn how Vite.js revolutionizes frontend development with its lightning-fast development server, native ES modules support, and blazing-fast production builds. You can check it out for yourself. Happy coding!.

Related Articles

A Complete Guide to Listing Docker Containers

We'll discuss the importance of listing docker containers, how to list running and stopped containers, listing the latest containers, and how to disable truncation of container names.

kubectl port-forward - Kubernetes Port Forwarding Explained

We'll see how to use kubectl port-forward to access internal Kubernetes services from outside the cluster.

Build Access Control Mechanism using Permify

We'll examine how to build an Access Control mechanism in Refine using Permify, an authorization as a service that helps you create any kind of authorization system easily with its panel.