# 应用实例

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

import { createApp } from 'vue'

const app = createApp({
  /* 根组件选项 */
})

# 根组件

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

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

    const app = createApp(App)

# 挂载应用

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

    <div id="app"></div>
    app.mount('#app')

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

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

同时需要注意的是:不同于其他资源注册方法,它的返回值是根实例而非应用实例。

# 应用配置

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

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

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

    app.component('TodoDeleteButton', TodoDeleteButton)

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

# 多个应用实例

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

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

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