Appearance
Vue3 快速开始
基于 Vite 创建 Vue 单页应用
确保你安装了最新版本的 Node.js,并且你的当前工作目录正是打算创建项目的目录。在命令行中运行以下命令
Bash
$ npm create vue@latest这一指令将会安装并执行 create-vue,它是 Vue 官方的项目脚手架工具。你将会看到一些诸如 TypeScript 和测试支持之类的可选功能提示:
Bash
Need to install the following packages:
create-vue@3.10.4
Ok to proceed? (y) y
> npx
> create-vue
Vue.js - The Progressive JavaScript Framework
√ Project name: ... <your-project-name>
√ Add TypeScript? ... No / Yes
√ Add JSX Support? ... No / Yes
√ Add Vue Router for Single Page Application development? ... No / Yes
√ Add Pinia for state management? ... No / Yes
√ Add Vitest for Unit Testing? ... No / Yes
√ Add an End-to-End Testing Solution? » No
√ Add ESLint for code quality? ... No / Yes
√ Add Vue DevTools 7 extension for debugging? (experimental) ... No / Yes
Scaffolding project in <your-project-path>...
Done.1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
如果不确定是否要开启某个功能,你可以直接按下回车键选择 No。在项目被创建后,通过以下步骤安装依赖并启动开发服务器:
Bash
$ cd <your-project-name>
$ npm install
$ npm run dev1
2
3
2
3
当你准备将应用发布到生产环境时,请运行:
Bash
$ npm run build此命令会在 ./dist 文件夹中为你的应用创建一个生产环境的构建版本。关于将应用上线生产环境的更多内容,请阅读生产环境部署指南。
通过 CDN 使用 Vue
通过 CDN 使用 Vue 时,不涉及 “构建步骤”。这使得设置更加简单,并且可以用于增强静态的 HTML 或与后端框架集成。但是,你将无法使用单文件组件 (SFC) 语法。详情请参考官方文档。
创建一个应用
应用实例
每个 Vue 应用都是通过 createApp 函数创建一个新的应用实例:
TypeScript
import { createApp } from 'vue'
const app = createApp({
/* 根组件选项 */
})1
2
3
4
5
2
3
4
5
根组件
我们传入 createApp 的对象实际上是一个组件,每个应用都需要一个 “根组件”,其他组件将作为其子组件。
如果你使用的是单文件组件,我们可以直接从另一个文件中导入根组件。
TypeScript
import { createApp } from 'vue'
// 从一个单文件组件中导入根组件
import App from './App.vue'
const app = createApp(App)1
2
3
4
5
2
3
4
5
挂载应用
应用实例必须在调用了 .mount() 方法后才会渲染出来。该方法接收一个 “容器” 参数,可以是一个实际的 DOM 元素或是一个 CSS 选择器字符串:
HTML
<div id="app"></div>TypeScript
app.mount('#app')应用根组件的内容将会被渲染在容器元素里面。容器元素自己不会被视为应用的一部分。
.mount() 方法应该始终在整个应用配置和资源注册完成后被调用。同时请注意,不同于其他资源注册方法,它的返回值是根组件实例而非应用实例。
DOM 内模板
当根组件没有设置 template 选项时,Vue 将自动使用容器的 innerHTML 作为模板:
HTML
<div id="app">
<button @click="count++">{{ count }}</button>
</div>1
2
3
2
3
TypeScript
import { createApp } from 'vue'
const app = createApp({
data() {
return {
count: 0
}
}
})
app.mount('#app')1
2
3
4
5
6
7
8
9
10
11
2
3
4
5
6
7
8
9
10
11
DOM 内模板通常用于无构建步骤的 Vue 应用程序。它们也可以与服务器端框架一起使用,其中根模板可能是由服务器动态生成的。
应用配置
应用实例会暴露一个 .config 对象允许我们配置一些应用级的选项,例如定义一个应用级的错误处理器,用来捕获所有子组件上的错误:
TypeScript
app.config.errorHandler = (err) => {
/* 处理错误 */
}1
2
3
2
3
应用实例还提供了一些方法来注册应用范围内可用的资源,例如注册一个组件:
TypeScript
app.component('TodoDeleteButton', TodoDeleteButton)这使得 TodoDeleteButton 在应用的任何地方都是可用的。
确保在挂载应用实例之前完成所有应用配置!
多个应用实例
应用实例并不只限于一个。createApp API 允许你在同一个页面中创建多个共存的 Vue 应用,而且每个应用都拥有自己的用于配置和全局资源的作用域。
TypeScript
const app1 = createApp({
/* ... */
})
app1.mount('#container-1')
const app2 = createApp({
/* ... */
})
app2.mount('#container-2')1
2
3
4
5
6
7
8
9
2
3
4
5
6
7
8
9
如果你正在使用 Vue 来增强服务端渲染 HTML,并且只想要 Vue 去控制一个大型页面中特殊的一小部分,应避免将一个单独的 Vue 应用实例挂载到整个页面上,而是应该创建多个小的应用实例,将它们分别挂载到所需的元素上去。