Vite creates a Vue3 project
Vite requires Node.js version >= 12.0.0. (
node -v
Check your current node version)
-
Use yarn:
yarn create @vitejs/app
Use npm:
npm init @vitejs/app
1. Enter the project name
Enter us here Project name: vite-vue3
2. Select the framework
Here select the framework we need to integrate: vue
vanilla: native js, without any framework integration
vue: vue3 framework, Only supports vue3
react: react framework
preact: lightweight react framework
lit -element: lightweight web component
svelte: svelte framework
3. Choose a different vue
Here we Select: vue
4. Project creation completed
5. Project structure
The project structure is very simple:
6. Start the project
Enter the project:
cd vite-vue3
Install dependencies:
npm install
- ##Run the project:
npm run dev
Or
npx vite ##Compile project: - npm run build
or
npx vite build
Startup speed
:
##Using jsx in Vue3
- yarn add @vitejs /plugin-vue-jsx -D
-
Use npm: npm i @vitejs/plugin-vue-jsx -D -
2. Register the plug-in
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()]
})
3. Use the plug-in
Method 1: Modify
App. vue Without jsx, App.vue
<script setup> import HelloWorld from './components/HelloWorld.vue'; </script> <template> <img src="/static/imghwm/default1.png" data-src="./assets/logo.png" class="lazy" alt="Vue logo" /> <HelloWorld msg="Hello Vue 3 + Vite" /> </template>
Using jsx, App.vue looks like this:
<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 src="/static/imghwm/default1.png" data-src="/src/main.js" class="lazy" alt="Vue logo" src={logo} /> <HelloWorld msg="Hello Vue 3 + Vite" /> </div> ), }); </script>
Method 2: Delete App.vue and create a new App.jsx
Create a new App.jsx file
import { defineComponent } from 'vue'; import HelloWorld from './components/HelloWorld.vue'; import logo from './assets/logo.png'; export default defineComponent({ setup () { return () => { return ( <div> <img src="/static/imghwm/default1.png" data-src="/src/main.js" class="lazy" alt="Vue logo" src={logo} /> <HelloWorld msg="Hello Vue 3 + Vite" /> </div> ) } } });Modify the introduction of main.jsimport App from './App.vue' changed to import App from './App'
import { createApp } from 'vue' import App from './App' createApp(App).mount('#app')Note Does not support eslint when saving, do eslint Verification
- Different from Webpack, Vite’s compilation entry is not a Javascript file, but index.html is used as the compilation entry. In index.html, main.js is loaded through . At this time, the request reaches the service layer of Vite
The above is the detailed content of Vite creates Vue3 projects and how Vue3 uses jsx. For more information, please follow other related articles on the PHP Chinese website!

前端有没有现成的库,可以直接用来绘制 Flowable 流程图的?下面本篇文章就跟小伙伴们介绍一下这两个可以绘制 Flowable 流程图的前端库。

vue不是前端css框架,而是前端JavaScript框架。Vue是一套用于构建用户界面的渐进式JS框架,是基于MVVM设计模式的前端框架,且专注于View层。Vue.js的优点:1、体积小;2、基于虚拟DOM,有更高的运行效率;3、双向数据绑定,让开发者不用再去操作DOM对象,把更多的精力投入到业务逻辑上;4、生态丰富、学习成本低。

Vue3如何更好地使用qrcodejs生成二维码并添加文字描述?下面本篇文章给大家介绍一下Vue3+qrcodejs生成二维码并添加文字描述,希望对大家有所帮助。

本篇文章我们来了解 Vue2.X 响应式原理,然后我们来实现一个 vue 响应式原理(写的内容简单)实现步骤和注释写的很清晰,大家有兴趣可以耐心观看,希望对大家有所帮助!


Hot AI Tools

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Undress AI Tool
Undress images for free

Clothoff.io
AI clothes remover

AI Hentai Generator
Generate AI Hentai for free.

Hot Article

Hot Tools

Dreamweaver Mac version
Visual web development tools

SAP NetWeaver Server Adapter for Eclipse
Integrate Eclipse with SAP NetWeaver application server.

Atom editor mac version download
The most popular open source editor

VSCode Windows 64-bit Download
A free and powerful IDE editor launched by Microsoft

SublimeText3 Chinese version
Chinese version, very easy to use
