data:image/s3,"s3://crabby-images/915af/915af8b3f01682ea3e00499d936abb83c453d37d" alt=""
Daniel Kelly
Teacher @ Vue School
Full Stack developer (10 years)
Husband and Father
data:image/s3,"s3://crabby-images/b0756/b0756ba983a4252c28972254a2179218328fb634" alt=""
What is Vite?
What is Vite?
Next generation front-end tooling that aims to provide a leaner and faster development experience
data:image/s3,"s3://crabby-images/2032e/2032eff2b8328e7ec1e189eab672dfee322dc8ff" alt=""
Current State of Development
Current State of Development
Current State of Development
data:image/s3,"s3://crabby-images/98478/98478446d844aab96ee431dabb4d62795b6e4925" alt=""
Current State of Development
data:image/s3,"s3://crabby-images/98478/98478446d844aab96ee431dabb4d62795b6e4925" alt=""
data:image/s3,"s3://crabby-images/98478/98478446d844aab96ee431dabb4d62795b6e4925" alt=""
Vite to the Rescue
data:image/s3,"s3://crabby-images/2696f/2696fdefa260848ae9de61b807f0eaf133e648d9" alt=""
Dev Server Start Times: 259ms
HMR: Essentially instant
Development Server
- Browser Support for ES Modules
-
ESBuild
- TypeScript
- Vue SFC
ESBuild Benchmarks
data:image/s3,"s3://crabby-images/b7f6d/b7f6d549b2efbd59138bc4f4268c1fadc914b27f" alt=""
Production Bundling
- Uses Rollup under the hood
-
Why Rollup?
- build speed
- tree-shaking
- output size
Why Vite
- Uses Rollup under the hood
-
Why Rollup?
- build speed
- tree-shaking
- output size
data:image/s3,"s3://crabby-images/98478/98478446d844aab96ee431dabb4d62795b6e4925" alt=""
Vite to the Rescue
- Native ES Modules
- ESBuild - GO based JS bundler
data:image/s3,"s3://crabby-images/2d453/2d45353087bfbcb835212d2d8a21f4cce9199a6d" alt=""
data:image/s3,"s3://crabby-images/98478/98478446d844aab96ee431dabb4d62795b6e4925" alt=""
Vite to the Rescue
- Native ES Modules
- ESBuild - GO based JS bundler
- How Vite Changes the Game for Vue and Web Developers - Alex Kyriakidis
data:image/s3,"s3://crabby-images/32acd/32acd5c31568c4070cbcea00709e2ce432d9ac7a" alt=""
Rapid Development with Vite
data:image/s3,"s3://crabby-images/9fa02/9fa02b3f1636ba2764d6c1ea4e3352094b32cfdd" alt=""
data:image/s3,"s3://crabby-images/b0756/b0756ba983a4252c28972254a2179218328fb634" alt=""
Process of Discovery
- Create brand new Vue CLI project
- Create brand new Vite Project
- Compare the differences
- Steps will cover 70% - 90%
- Don't look at the steps as something to memorize
Process of Discovery
data:image/s3,"s3://crabby-images/cd3f9/cd3f990b208ff2a77137fa2717349976fe97c6a1" alt=""
data:image/s3,"s3://crabby-images/98478/98478446d844aab96ee431dabb4d62795b6e4925" alt=""
Step # 1
Update Dependencies
// package.json
{
//...
"dependencies": {
"core-js": "^3.6.5",
"vue": "^2.6.11",
"vue-router": "^3.2.0"
},
"devDependencies": {
"@vue/cli-plugin-babel": "~4.5.0",
"@vue/cli-plugin-eslint": "~4.5.0",
"@vue/cli-plugin-router": "~4.5.0",
"@vue/cli-service": "~4.5.0",
"@vue/eslint-config-prettier": "^6.0.0",
"babel-eslint": "^10.1.0",
"eslint": "^6.7.2",
"eslint-plugin-prettier": "^3.3.1",
"eslint-plugin-vue": "^6.2.2",
"prettier": "^2.2.1",
"sass": "^1.26.5",
"sass-loader": "^8.0.2",
"vue-template-compiler": "^2.6.11"
}
}
data:image/s3,"s3://crabby-images/98478/98478446d844aab96ee431dabb4d62795b6e4925" alt=""
Step # 1
Update Dependencies
// package.json
{
//...
"dependencies": {
"core-js": "^3.6.5",
"vue": "^2.6.11",
"vue-router": "^3.2.0"
},
"devDependencies": {
"@vue/eslint-config-prettier": "^6.0.0",
"babel-eslint": "^10.1.0",
"eslint": "^6.7.2",
"eslint-plugin-prettier": "^3.3.1",
"eslint-plugin-vue": "^6.2.2",
"prettier": "^2.2.1",
"sass": "^1.26.5",
"sass-loader": "^8.0.2",
"vue-template-compiler": "^2.6.11"
}
}
data:image/s3,"s3://crabby-images/98478/98478446d844aab96ee431dabb4d62795b6e4925" alt=""
Step # 1
Update Dependencies
// package.json
{
//...
"dependencies": {
"core-js": "^3.6.5",
"vue": "^2.6.11",
"vue-router": "^3.2.0"
},
"devDependencies": {
"@vue/eslint-config-prettier": "^6.0.0",
"babel-eslint": "^10.1.0",
"eslint": "^6.7.2",
"eslint-plugin-prettier": "^3.3.1",
"eslint-plugin-vue": "^6.2.2",
"prettier": "^2.2.1",
"sass": "^1.26.5",
"vue-template-compiler": "^2.6.11"
}
}
data:image/s3,"s3://crabby-images/98478/98478446d844aab96ee431dabb4d62795b6e4925" alt=""
Step # 1
Update Dependencies
// package.json
{
//...
"dependencies": {
"core-js": "^3.6.5",
"vue": "^2.6.11",
"vue-router": "^3.2.0"
},
"devDependencies": {
"@vue/eslint-config-prettier": "^6.0.0",
"babel-eslint": "^10.1.0",
"eslint": "^6.7.2",
"eslint-plugin-prettier": "^3.3.1",
"eslint-plugin-vue": "^6.2.2",
"prettier": "^2.2.1",
"sass": "^1.26.5",
}
}
data:image/s3,"s3://crabby-images/98478/98478446d844aab96ee431dabb4d62795b6e4925" alt=""
Step # 1
Update Dependencies
$ npm i -D vite
data:image/s3,"s3://crabby-images/98478/98478446d844aab96ee431dabb4d62795b6e4925" alt=""
Step # 1
Update Dependencies
$ npm i -D vite-plugin-vue2
data:image/s3,"s3://crabby-images/98478/98478446d844aab96ee431dabb4d62795b6e4925" alt=""
Step # 1
Update Dependencies
$ npm i -D @vitejs/plugin-vue
data:image/s3,"s3://crabby-images/98478/98478446d844aab96ee431dabb4d62795b6e4925" alt=""
Step # 1
Update Dependencies
$ npm prune
data:image/s3,"s3://crabby-images/98478/98478446d844aab96ee431dabb4d62795b6e4925" alt=""
Step # 2
Provide Support only For Modern Browsers
data:image/s3,"s3://crabby-images/853e1/853e187eb9e77e66277f6f2a8a80637f557a7b35" alt=""
https://kangax.github.io/compat-table/es6/
data:image/s3,"s3://crabby-images/98478/98478446d844aab96ee431dabb4d62795b6e4925" alt=""
Step # 2
Provide Support only For Modern Browsers
data:image/s3,"s3://crabby-images/d2431/d2431941360f34cd3182db91ee1a6d181908ff69" alt=""
data:image/s3,"s3://crabby-images/98478/98478446d844aab96ee431dabb4d62795b6e4925" alt=""
Step # 2
Provide Support only For Modern Browsers
data:image/s3,"s3://crabby-images/1b914/1b9146b4bdeb5b2400da80ce914c10eba726ae73" alt=""
data:image/s3,"s3://crabby-images/98478/98478446d844aab96ee431dabb4d62795b6e4925" alt=""
// package.json
{
//...
"dependencies": {
"core-js": "^3.6.5",
"vue": "^2.6.11",
"vue-router": "^3.2.0"
},
"devDependencies": {
"babel-eslint": "^10.1.0",
"eslint": "^6.7.2",
"eslint-plugin-prettier": "^3.3.1",
"eslint-plugin-vue": "^6.2.2",
"prettier": "^2.2.1",
"sass": "^1.26.5",
}
}
Step # 2
Provide Support only For Modern Browsers
data:image/s3,"s3://crabby-images/98478/98478446d844aab96ee431dabb4d62795b6e4925" alt=""
// package.json
{
//...
"dependencies": {
"vue": "^2.6.11",
"vue-router": "^3.2.0"
},
"devDependencies": {
"eslint": "^6.7.2",
"eslint-plugin-prettier": "^3.3.1",
"eslint-plugin-vue": "^6.2.2",
"prettier": "^2.2.1",
"sass": "^1.26.5",
}
}
Step # 2
Provide Support only For Modern Browsers
data:image/s3,"s3://crabby-images/98478/98478446d844aab96ee431dabb4d62795b6e4925" alt=""
// .eslintrc.js
module.exports = {
root: true,
env: {
node: true,
},
extends: ["plugin:vue/essential", "eslint:recommended", "@vue/prettier"],
parserOptions: {
parser: "babel-eslint",
},
rules: {
"no-console": process.env.NODE_ENV === "production" ? "warn" : "off",
"no-debugger": process.env.NODE_ENV === "production" ? "warn" : "off",
},
};
Step # 2
Provide Support only For Modern Browsers
data:image/s3,"s3://crabby-images/98478/98478446d844aab96ee431dabb4d62795b6e4925" alt=""
// .eslintrc.js
module.exports = {
root: true,
env: {
node: true,
},
extends: ["plugin:vue/essential", "eslint:recommended", "@vue/prettier"],
rules: {
"no-console": process.env.NODE_ENV === "production" ? "warn" : "off",
"no-debugger": process.env.NODE_ENV === "production" ? "warn" : "off",
},
};
Step # 2
Provide Support only For Modern Browsers
data:image/s3,"s3://crabby-images/98478/98478446d844aab96ee431dabb4d62795b6e4925" alt=""
// .eslintrc.js
module.exports = {
root: true,
env: {
node: true,
},
extends: ["plugin:vue/essential", "eslint:recommended", "@vue/prettier"],
rules: {
"no-console": process.env.NODE_ENV === "production" ? "warn" : "off",
"no-debugger": process.env.NODE_ENV === "production" ? "warn" : "off",
},
};
Step # 2
Provide Support only For Modern Browsers
data:image/s3,"s3://crabby-images/98478/98478446d844aab96ee431dabb4d62795b6e4925" alt=""
// .eslintrc.js
module.exports = {
root: true,
env: {
node: true,
es2021: true,
},
extends: ["plugin:vue/essential", "eslint:recommended", "@vue/prettier"],
rules: {
"no-console": process.env.NODE_ENV === "production" ? "warn" : "off",
"no-debugger": process.env.NODE_ENV === "production" ? "warn" : "off",
},
};
Step # 2
Provide Support only For Modern Browsers
data:image/s3,"s3://crabby-images/98478/98478446d844aab96ee431dabb4d62795b6e4925" alt=""
$ npm install eslint@8 eslint-plugin-vue@8
Step # 2
Provide Support only For Modern Browsers
data:image/s3,"s3://crabby-images/98478/98478446d844aab96ee431dabb4d62795b6e4925" alt=""
$ npm prune
Step # 2
Provide Support only For Modern Browsers
data:image/s3,"s3://crabby-images/98478/98478446d844aab96ee431dabb4d62795b6e4925" alt=""
Step # 3
Add Vite Config
// vite.config.js
import { defineConfig } from 'vite'
import vue from '@vitejs/plugin-vue'
export default defineConfig({
//https://vitejs.dev/config/
plugins: [vue()]
})
data:image/s3,"s3://crabby-images/98478/98478446d844aab96ee431dabb4d62795b6e4925" alt=""
Step # 3
Add Vite Config
// vite.config.js
import { defineConfig } from 'vite'
import { createVuePlugin as vue } from "vite-plugin-vue2";
export default defineConfig({
//https://vitejs.dev/config/
plugins: [vue()]
})
data:image/s3,"s3://crabby-images/98478/98478446d844aab96ee431dabb4d62795b6e4925" alt=""
Step # 3
Add Vite Config
// vite.config.js
import { defineConfig } from 'vite'
import vue from '@vitejs/plugin-vue'
import { fileURLToPath, URL } from 'node:url'
export default defineConfig({
//https://vitejs.dev/config/
plugins: [vue()],
resolve: {
alias: {
'@': fileURLToPath(new URL('./src', import.meta.url))
}
}
})
data:image/s3,"s3://crabby-images/98478/98478446d844aab96ee431dabb4d62795b6e4925" alt=""
Step # 4
Move the index.html
data:image/s3,"s3://crabby-images/33d3f/33d3fa23d5060aea7979f7ab80bb1142513a0b4b" alt=""
data:image/s3,"s3://crabby-images/98478/98478446d844aab96ee431dabb4d62795b6e4925" alt=""
Step # 4
Move the index.html
<!--index.html-->
<!DOCTYPE html>
<html lang="">
<head>
<meta charset="utf-8">
<meta http-equiv="X-UA-Compatible" content="IE=edge">
<meta name="viewport" content="width=device-width,initial-scale=1.0">
<link rel="icon" href="<%= BASE_URL %>favicon.ico">
<title><%= htmlWebpackPlugin.options.title %></title>
</head>
<body>
<noscript>
<strong>We're sorry but <%= htmlWebpackPlugin.options.title %> doesn't work properly without JavaScript enabled. Please enable it to continue.</strong>
</noscript>
<div id="app"></div>
<!-- built files will be auto injected -->
</body>
</html>
data:image/s3,"s3://crabby-images/98478/98478446d844aab96ee431dabb4d62795b6e4925" alt=""
Step # 4
Move the index.html
<!--index.html-->
<!DOCTYPE html>
<html lang="">
<head>
<meta charset="utf-8">
<meta http-equiv="X-UA-Compatible" content="IE=edge">
<meta name="viewport" content="width=device-width,initial-scale=1.0">
<link rel="icon" href="<%= BASE_URL %>favicon.ico">
<title><%= htmlWebpackPlugin.options.title %></title>
</head>
<body>
<noscript>
<strong>We're sorry but <%= htmlWebpackPlugin.options.title %> doesn't work properly without JavaScript enabled. Please enable it to continue.</strong>
</noscript>
<div id="app"></div>
<!-- built files will be auto injected -->
</body>
</html>
data:image/s3,"s3://crabby-images/98478/98478446d844aab96ee431dabb4d62795b6e4925" alt=""
Step # 4
Move the index.html
<!--index.html-->
<!DOCTYPE html>
<html lang="">
<head>
<meta charset="utf-8">
<meta http-equiv="X-UA-Compatible" content="IE=edge">
<meta name="viewport" content="width=device-width,initial-scale=1.0">
<link rel="icon" href="<%= BASE_URL %>favicon.ico">
<title>Hard Coded Title</title>
</head>
<body>
<noscript>
<strong>We're sorry but this app doesn't work properly without JavaScript enabled. Please enable it to continue.</strong>
</noscript>
<div id="app"></div>
<!-- built files will be auto injected -->
</body>
</html>
data:image/s3,"s3://crabby-images/98478/98478446d844aab96ee431dabb4d62795b6e4925" alt=""
Step # 4
Move the index.html
<!--index.html-->
<!DOCTYPE html>
<html lang="">
<head>
<meta charset="utf-8">
<meta http-equiv="X-UA-Compatible" content="IE=edge">
<meta name="viewport" content="width=device-width,initial-scale=1.0">
<link rel="icon" href="<%= BASE_URL %>favicon.ico">
<title>Hard Coded Title</title>
</head>
<body>
<noscript>
<strong>We're sorry but this app doesn't work properly without JavaScript enabled. Please enable it to continue.</strong>
</noscript>
<div id="app"></div>
<!-- built files will be auto injected -->
</body>
</html>
data:image/s3,"s3://crabby-images/98478/98478446d844aab96ee431dabb4d62795b6e4925" alt=""
Step # 4
Move the index.html
<!--index.html-->
<!DOCTYPE html>
<html lang="">
<head>
<meta charset="utf-8">
<meta http-equiv="X-UA-Compatible" content="IE=edge">
<meta name="viewport" content="width=device-width,initial-scale=1.0">
<link rel="icon" href="/favicon.ico">
<title>Hard Coded Title</title>
</head>
<body>
<noscript>
<strong>We're sorry but this app doesn't work properly without JavaScript enabled. Please enable it to continue.</strong>
</noscript>
<div id="app"></div>
<!-- built files will be auto injected -->
</body>
</html>
data:image/s3,"s3://crabby-images/98478/98478446d844aab96ee431dabb4d62795b6e4925" alt=""
Step # 4
Move the index.html
<!--index.html-->
<!DOCTYPE html>
<html lang="">
<head>
<meta charset="utf-8">
<meta http-equiv="X-UA-Compatible" content="IE=edge">
<meta name="viewport" content="width=device-width,initial-scale=1.0">
<link rel="icon" href="/favicon.ico">
<title>Hard Coded Title</title>
</head>
<body>
<noscript>
<strong>We're sorry but this app doesn't work properly without JavaScript enabled. Please enable it to continue.</strong>
</noscript>
<div id="app"></div>
<!-- built files will be auto injected -->
</body>
</html>
data:image/s3,"s3://crabby-images/98478/98478446d844aab96ee431dabb4d62795b6e4925" alt=""
Step # 4
Move the index.html
<!--index.html-->
<!DOCTYPE html>
<html lang="">
<head>
<meta charset="utf-8">
<meta http-equiv="X-UA-Compatible" content="IE=edge">
<meta name="viewport" content="width=device-width,initial-scale=1.0">
<link rel="icon" href="/favicon.ico">
<title>Hard Coded Title</title>
</head>
<body>
<noscript>
<strong>We're sorry but this app doesn't work properly without JavaScript enabled. Please enable it to continue.</strong>
</noscript>
<div id="app"></div>
<script type="module" src="/src/main.js"></script>
</body>
</html>
data:image/s3,"s3://crabby-images/98478/98478446d844aab96ee431dabb4d62795b6e4925" alt=""
Step # 5
Update Scripts in package.json
// package.json
{
//...
"scripts": {
"serve": "vue-cli-service serve",
"build": "vue-cli-service build",
"lint": "vue-cli-service lint"
},
//...
}
data:image/s3,"s3://crabby-images/98478/98478446d844aab96ee431dabb4d62795b6e4925" alt=""
Step # 5
Update Scripts in package.json
// package.json
{
//...
"scripts": {
"dev": "vite",
"build": "vite build",
"serve": "vite preview",
},
//...
}
data:image/s3,"s3://crabby-images/98478/98478446d844aab96ee431dabb4d62795b6e4925" alt=""
Step # 5
Update Scripts in package.json
// package.json
{
//...
"scripts": {
"dev": "vite",
"build": "vite build",
"serve": "vite preview",
"lint": "eslint --ext .js,.vue --ignore-path .gitignore --fix src"
},
//...
}
data:image/s3,"s3://crabby-images/98478/98478446d844aab96ee431dabb4d62795b6e4925" alt=""
Step # 6
Update Environment Variables
.env # loaded in all cases
.env.local # loaded in all cases, ignored by git
.env.[mode] # only loaded in specified mode
.env.[mode].local # only loaded in specified mode, ignored by git
data:image/s3,"s3://crabby-images/98478/98478446d844aab96ee431dabb4d62795b6e4925" alt=""
Step # 6
Update Environment Variables
// /src/router/index.js
//...
const router = new VueRouter({
mode: "history",
base: process.env.BASE_URL,
routes,
});
data:image/s3,"s3://crabby-images/98478/98478446d844aab96ee431dabb4d62795b6e4925" alt=""
Step # 6
Update Environment Variables
// /src/router/index.js
//...
const router = new VueRouter({
mode: "history",
base: import.meta.env.BASE_URL,
routes,
});
data:image/s3,"s3://crabby-images/98478/98478446d844aab96ee431dabb4d62795b6e4925" alt=""
Step # 6
Update Environment Variables
// .env
VUE_APP_MY_HEADLESS_CMS_API_KEY=123
data:image/s3,"s3://crabby-images/98478/98478446d844aab96ee431dabb4d62795b6e4925" alt=""
Step # 6
Update Environment Variables
// .env
VITE_MY_HEADLESS_CMS_API_KEY=123
data:image/s3,"s3://crabby-images/98478/98478446d844aab96ee431dabb4d62795b6e4925" alt=""
Step # 7
Add .vue extension to SFC imports
// Home.vue
// .vue is required
import HelloWorld from "@/components/HelloWorld.vue";
data:image/s3,"s3://crabby-images/98478/98478446d844aab96ee431dabb4d62795b6e4925" alt=""
Step # 7
Add .vue extension to SFC imports
// vite.config.js
//...
export default defineConfig({
plugins: [vue()],
resolve: {
extensions:
['.mjs', '.js', '.ts', '.jsx', '.tsx', '.json', '.vue'],
//...
},
});
data:image/s3,"s3://crabby-images/98478/98478446d844aab96ee431dabb4d62795b6e4925" alt=""
Step # 8
Clean Up Magic Comments
// router/index.js
//...
{
path: "/about",
name: "About",
component: () =>
import( /* webpackChunkName: "about" */ "../views/About.vue"),
},
data:image/s3,"s3://crabby-images/98478/98478446d844aab96ee431dabb4d62795b6e4925" alt=""
Step # 8
Clean Up Magic Comments
// router/index.js
//...
{
path: "/about",
name: "About",
component: () =>
import("../views/About.vue"), // About.37a9fa9f.js,
},
data:image/s3,"s3://crabby-images/98478/98478446d844aab96ee431dabb4d62795b6e4925" alt=""
Step # 9
Enjoy an improved developer experience
data:image/s3,"s3://crabby-images/98478/98478446d844aab96ee431dabb4d62795b6e4925" alt=""
data:image/s3,"s3://crabby-images/30f90/30f908006ffa624cba9b975b6663d146ab486a17" alt=""
data:image/s3,"s3://crabby-images/6e2b9/6e2b9ba496832b7280b95fc21ae294336e4ea318" alt=""
data:image/s3,"s3://crabby-images/46044/460442347fdf87c8efde9280d8e8796e2d7a8239" alt=""
Vue School Courses
data:image/s3,"s3://crabby-images/98478/98478446d844aab96ee431dabb4d62795b6e4925" alt=""
Other Great Courses
#1 Training Platform for Vue.js
800+ Video Lessons
140,000 users
data:image/s3,"s3://crabby-images/e3cbc/e3cbcccf09e8e14dad927dc39fe2e06badc69486" alt=""
data:image/s3,"s3://crabby-images/d34fc/d34fc9d547728b0fbd7ac5ab752ccea787a7039e" alt=""
data:image/s3,"s3://crabby-images/26462/2646213ad99da0117b34059db46d80b8b4b27417" alt=""
data:image/s3,"s3://crabby-images/206dd/206ddcd40c31d464673cdac708c56cb303225498" alt=""
data:image/s3,"s3://crabby-images/76db9/76db9281c129896b4fc43b2c9dd902dcb455e425" alt=""
data:image/s3,"s3://crabby-images/4b4fb/4b4fb33c27c1feea1d161398c028ab58104d4792" alt=""
Alex Kyriakidis
Daniel Kelly
Debbie O'Brien
Maria Lamardo
Roman Kuba
Filip Rakowski
Lydia Hallie
data:image/s3,"s3://crabby-images/9a037/9a03743fde871fd601eb203439ac83b5de2b24ef" alt=""
data:image/s3,"s3://crabby-images/c36ab/c36abf1ad030c03b3b8aa2336cea255b1ded9c46" alt=""
Anthony Fu
data:image/s3,"s3://crabby-images/4af17/4af1752ebc1e4e28e7b093809c9a3516aa7e1bca" alt=""
data:image/s3,"s3://crabby-images/18cd0/18cd0bb5226e29d3faff9060336d99aad3d8edf9" alt=""
Workshops
Interested? Talk to our team at the conference or send us an email
💌 team@vueschool.io
data:image/s3,"s3://crabby-images/0725c/0725c15f8e0aad873950cfe745289ee9a11d3455" alt=""
data:image/s3,"s3://crabby-images/9b53c/9b53c9be6a49c03fc77490aed5b459e3387c08a2" alt=""
💌 team@vueschool.io
1 day $3,500
2 day $6,000
- Vue.js Fundamentals
- Migrating from Vue 2 to Vue 3
- Vue 3 Composition API
- State Management with Pina
- TypeScript + Vue
2 days $6,000
🔥
Berlin Conf Workshop Special
- Migrating from Nuxt 2 to Nuxt 3
data:image/s3,"s3://crabby-images/c199e/c199eb7235ca7cf173144654f945e844b58a2559" alt=""
data:image/s3,"s3://crabby-images/d8022/d80225812cc20dae7fc18025d7462b047be2bb6e" alt=""
data:image/s3,"s3://crabby-images/d8022/d80225812cc20dae7fc18025d7462b047be2bb6e" alt=""
data:image/s3,"s3://crabby-images/d8022/d80225812cc20dae7fc18025d7462b047be2bb6e" alt=""
data:image/s3,"s3://crabby-images/d8022/d80225812cc20dae7fc18025d7462b047be2bb6e" alt=""
data:image/s3,"s3://crabby-images/8cd6d/8cd6de8f4d574d5a630085f13ccc07fcc52b8689" alt=""
data:image/s3,"s3://crabby-images/d8022/d80225812cc20dae7fc18025d7462b047be2bb6e" alt=""
data:image/s3,"s3://crabby-images/06109/06109574ee0695afb5b2bf4c91b71fc65f2f5837" alt=""
data:image/s3,"s3://crabby-images/31627/31627b6ab9e620401877122d8c7aa2d361036b23" alt=""
data:image/s3,"s3://crabby-images/8cd6d/8cd6de8f4d574d5a630085f13ccc07fcc52b8689" alt=""
data:image/s3,"s3://crabby-images/d8022/d80225812cc20dae7fc18025d7462b047be2bb6e" alt=""
data:image/s3,"s3://crabby-images/06109/06109574ee0695afb5b2bf4c91b71fc65f2f5837" alt=""
data:image/s3,"s3://crabby-images/8cd6d/8cd6de8f4d574d5a630085f13ccc07fcc52b8689" alt=""
Grab Some Swag 🤗
data:image/s3,"s3://crabby-images/6f11d/6f11d01efa31e2850e86d73b8e765478d9734740" alt=""
data:image/s3,"s3://crabby-images/c199e/c199eb7235ca7cf173144654f945e844b58a2559" alt=""
data:image/s3,"s3://crabby-images/f0a24/f0a2459a2f2b959b1eb2b26310d14fdc1280ccd6" alt=""
data:image/s3,"s3://crabby-images/4af17/4af1752ebc1e4e28e7b093809c9a3516aa7e1bca" alt=""
Vue Corporate Training
NEW
📺
Vue Video
Courses
👨🏫
Live Workshops
💬
Bi-weekly Support
Sessions
🧑🔧
Database for hiring
Vue devs
Nuxt Nation
NEW
data:image/s3,"s3://crabby-images/8286a/8286a5c5f09bd9a790cf10e6ac9e55af6bd9a530" alt=""
data:image/s3,"s3://crabby-images/4c402/4c402720b25f726cfaee6b7780f793a8c1b234ec" alt=""
data:image/s3,"s3://crabby-images/915af/915af8b3f01682ea3e00499d936abb83c453d37d" alt=""
Thank You!
How to Migrate to Vite
By Daniel Kelly
How to Migrate to Vite
- 2,090