创建一个 Vue 应用 您所在的位置:网站首页 vue模板使用$函数 创建一个 Vue 应用

创建一个 Vue 应用

#创建一个 Vue 应用 | 来源: 网络整理| 查看: 265

# 应用实例

每个 Vue 应用都是通过 createApp 函数创建一个新的 应用实例:

import { createApp } from 'vue' const app = createApp({ /* 根组件选项 */ }) # 根组件

传入 createApp 的对象实际上是一个组件,每个应用都需要一个 根组件,其他组件将作为其子组件。

如果你使用的是单文件组件,我们可以直接从另一个文件中导入根组件。

import { createApp } from 'vue' // 从一个单文件组件中导入根组件 import App from './App.vue' const app = createApp(App)

大多数真实的应用都是由一棵 嵌套的、可重用的 组件树组成的。例如:一个待办事项(Todos)应用的组件树可能是这样的:

App (root component) ├─ TodoList │ └─ TodoItem │ ├─ TodoDeleteButton │ └─ TodoEditButton └─ TodoFooter ├─ TodoClearButton └─ TodoStatistics # 挂载应用

应用实例必须在调用了 .mount() 方法后才会渲染出来。该方法接收一个 “容器” 参数,可以是一个实际的 DOM 元素或是一个 CSS 选择器字符串:

app.mount('#app')

应用根组件的内容将会被渲染在容器元素里面。容器元素自己将 不会 被视为应用的一部分。

.mount() 方法应该始终在整个应用配置和资源注册完成后被调用。

提示

.mount() 方法不同于其他资源注册方法,它的返回值是 根组件实例 而非 应用实例

# DOM 中的根组件模板

当在未采用构建流程的情况下使用 Vue 时,可以在挂载容器中直接书写根组件模板:

{{ count }} import { createApp } from 'vue' const app = createApp({ data() { return { count: 0 } } }) app.mount('#app')

当根组件没有设置 template 选项时,Vue 将自动使用容器的 innerHTML 作为模板。

# 应用配置

应用实例会暴露一个 .config 对象,用于配置一些应用级的选项。例如:定义一个应用级的错误处理器,用来捕获所有子组件上的错误。

app.config.errorHandler = (err) => { /* 处理错误 */ }

应用实例还提供了一些方法来注册应用范围内可用的资源。例如:注册一个组件。

app.component('TodoDeleteButton', TodoDeleteButton)

这使得 TodoDeleteButton 在应用的任何地方都是可用的。

确保在挂载应用实例之前完成所有应用配置!

# 多个应用实例

应用实例并不只限于一个。createApp API 函数允许你在同一个页面中创建多个共存的 Vue 应用,而且每个应用都拥有自己的用于配置和全局资源的 作用域。

const app1 = createApp({ /* ... */ }) app1.mount('#container-1') const app2 = createApp({ /* ... */ }) app2.mount('#container-2')

如果你正在使用 Vue 来增强服务端渲染 HTML,并且只想要 Vue 去控制一个大型页面中特殊的一小部分,应避免将一个单独的 Vue 应用实例挂载到整个页面上,而是应该创建多个小的应用实例,将它们分别挂载到所需的元素上去



【本文地址】

公司简介

联系我们

今日新闻

    推荐新闻

    专题文章
      CopyRight 2018-2019 实验室设备网 版权所有