Vite 需要 Node.js 版本 >= 12.0.0。(
node -v
查看自己当前的node版本)
使用 yarn:yarn create @vitejs/app
使用 npm:npm init @vitejs/app
这里输入我们的项目名称:vite-vue3
这里选择我们需要集成的框架:vue
vanilla:原生js,没有任何框架集成
vue:vue3框架,只支持vue3
react:react框架
preact:轻量化react框架
lit-element:轻量级web组件
svelte:svelte框架
这里我们选择:vue
项目结构非常简单:
进入项目:cd vite-vue3
安装依赖:npm install
运行项目:npm run dev
或 npx vite
编译项目:npm run build
或 npx vite build
启动速度极快:
Vite创建的Vue3项目中是无法直接使用jsx 的,需要引入插件来实现
使用 yarn:yarn add @vitejs/plugin-vue-jsx -D
使用 npm: npm i @vitejs/plugin-vue-jsx -D
vite.config.js 中:
import { defineConfig } from 'vite'import vue from '@vitejs/plugin-vue'import vueJsx from "@vitejs/plugin-vue-jsx";// https://vitejs.dev/config/export default defineConfig({ plugins: [vue(), vueJsx()]})
方法一:修改App.vue
不使用 jsx,App.vue
是这样:
<script setup>import HelloWorld from './components/HelloWorld.vue';</script><template> <img alt="Vue logo" src="./assets/logo.png" /> <HelloWorld msg="Hello Vue 3 + Vite" /></template>
使用 jsx,App.vue是这样:
<script lang="jsx">import { defineComponent } from 'vue';import HelloWorld from './components/HelloWorld.vue';import logo from './assets/logo.png';export default defineComponent({ render: () => ( <div> <img alt="Vue logo" src={logo} /> <HelloWorld msg="Hello Vue 3 + Vite" /> </div> ),});</script>
方法二:删除App.vue,新建App.jsx
新建App.jsx文件
import { defineComponent } from 'vue';import HelloWorld from './components/HelloWorld.vue';import logo from './assets/logo.png';export default defineComponent({ setup () { return () => { return ( <div> <img alt="Vue logo" src={logo} /> <HelloWorld msg="Hello Vue 3 + Vite" /> </div> ) } }});
再修改main.js的引入
import App from './App.vue' 改为 import App from './App'
import { createApp } from 'vue'import App from './App'createApp(App).mount('#app')
不支持eslint在保存时,做eslint校验
与Webpack不同,Vite的编译入口不是Javascript文件,而是以index.html作为编译入口。在index.html中,通过<script type="module" src="/src/main.js"></script>加载main.js,这时请求到达了vite的serve层
以上就是Vite创建Vue3项目及Vue3使用jsx的方法的详细内容,更多请关注Gxl网其它相关文章!