Don’t be a faster man than Vite

Yu Said Vite was fast, which I didn’t believe at first. It wasn’t until I used it myself that I was blown away by the speed of the Vite.

Vite is so fast because it uses the browser-supported ESM approach to speed up development by eliminating the need for a development environment to package code.

Vite starts a server in development mode that intercepts requests from the browser, and the browser sends a request to the server to get the corresponding module. Vite handles modules that the browser doesn’t know about, such as importing a single-file component. The.vue file will compile the.vue file on the server and return the compiled results to the browser.

Old and new packaging tools big PK

Let’s compare Vite to vue-CLI

1.Vite can run directly in development mode without packaging

The parsing of the files is left to the serverCopy the code

2. In vue-CLI development mode, the project must be packaged to run

Because SFC is compiledCopy the code

3.Vite is packaged using rollup in the production environment. Rollup is packaged based on ESM, while VUe-CLI is packaged using Webpack

To put it simply, Webpack is js packed with JS!! Esbuild is developed in go!! Rollup is more scientific and less burdensome, webpack is too hard to understand!!Copy the code

In general, Vite has the following advantages:

  • Fast cold start (because no packing is required)

  • Compile on demand (code is compiled when it needs to be loaded)

  • Module hot update

Vite usage mode

The front end must be inseparable from NPM or YARN, the installation of the project we do not need to repeat, just follow the steps.

Use NPM:

    npm init vite@latest
Copy the code

Using Yarn:

    yarn create vite
Copy the code

You can also specify the project name and the template you want to use directly from the command line options, such as creating a vite+vue project:

//npm 6.x
npm init vite[@latest ](</latest >)my-vue-app --template vue

// NPM 7+, need extra double line:
npm init vite[@latest ](</latest >)my-vue-app -- --template vue

//yarn
yarn create vite my-vue-app --template vue
Copy the code

Here we create a Vue project with the following structure:

The project structure is simple, just an HTML file and a main.js file

Package. json is also very simple:

We only need NPM run dev or NPM run build for Vite startup and package instructions.

To start the project, run the NPM run dev command.

Maybe our project is just an initialization project, people would say that the amount of code is not very much, so the startup speed may not be too big feeling, but compared with vuecli version of the startup time, there is still a significant difference.

Open developer tools, switch to the Network TAB, and refresh your browser:

We can see that the request has a.vue ending file

This web server that vite starts, he hijacks requests for files that end in.vue, he parses the.vue files into JS files, and he sets the content-Type in the response header to application/javascript, just to tell the browser, What I’m sending you now is a JS script.

The response body is the js module that the server parsed. it imports the helloWorld single-file component, and it imports the app.vue module below.

Here we import the render function of app.vue, but app.vue is a single file component we wrote. We didn’t write the render function when we wrote it, so we can import the render function because the server did something special to it. Here, as soon as the module is loaded, a request is made to the server.

Moving on to the response body of helloWorld.vue, it does exactly the same thing as the.vue file above.

Further down the line, the app.vue file is requested, and this time with parameters. After this request is sent to the server, the server will compile the app.vue single-file component into the render function using the compiler- SFC module in vUE

And we can see in the red box that the static nodes in the component are promoted.

This is how Vite’s development mode works. It uses the browser-supported ESM to load modules. In development mode, it doesn’t pack up all the code, leaving all module requests to the server to handle.

You can use the NPM run build command to see the results of the vite package when the server handles modules that are not recognized by the browser. We won’t go into any further details here. This is the basic principle of Vite and how to use it.

Vite understanding is still shallow, if there are deficiencies please correct