Vue-创建应用

268 阅读2分钟
  • 1.应用实例
import { createApp } from 'vue'

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

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

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

const app = createApp(App)
  • 3.挂载应用

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

<div id="app"></div>

app.mount('#app')

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

.mount()方法应始终在整个应用配置和资源注册完成后被调用。用时需注意,不同于其他自愿注册方法,它的返回值是根组件实例而非应用实例。

  • 4.DOM中的根组件模板

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

<div id="app">
    <button @click="count++">{{ count }}</button>
</div>

import { createApp } from 'vue'

const app = createApp({
    data(){
        return {
            count: 0
        }
    }
})

app.mount("#app")

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

  • 5.应用配置

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

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

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

app.component('TodoDeleteButton', TodoDeleteButton)

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

  • 6.多个应用实例

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

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

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

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