百科狗-知识改变命运!
--

应用实例 API ​

梵高2年前 (2023-11-21)阅读数 23#技术干货
文章标签组件

应用实例 API ​

createApp() ​

创建一个应用实例。

  • 类型

    ts
    function createApp(rootComponent: Component, rootProps?: object): App
  • 详细信息

    第一个参数是根组件。第二个参数可选,它是要传递给根组件的 props。

  • 示例

    可以直接内联根组件:

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

    也可以使用从别处导入的组件:

    js
    import { createApp } from 'vue'import App from './App.vue'const app = createApp(App)
  • 参考指南 - 创建一个 Vue 应用实例

createSSRApp() ​

以 SSR 激活模式创建一个应用实例。用法与 createApp() 完全相同。

app.mount() ​

将应用实例挂载在一个容器元素中。

  • 类型

    ts
    interface App { mount(rootContainer: Element | string): ComponentPublicInstance}
  • 详细信息

    参数可以是一个实际的 DOM 元素或一个 CSS 选择器 (使用第一个匹配到的元素)。返回根组件的实例。

    如果该组件有模板或定义了渲染函数,它将替换容器内所有现存的 DOM 节点。否则在运行时编译器可用的情况下,容器元素的 innerHTML 将被用作模板。

    在 SSR 激活模式下,它将激活容器内现有的 DOM 节点。如果出现了激活不匹配,那么现有的 DOM 节点将会被修改以匹配客户端的实际渲染结果。

    对于每个应用实例,mount() 仅能调用一次。

  • 示例

    js
    import { createApp } from 'vue'const app = createApp(/* ... */)app.mount('#app')

    应用实例 API ​

    也可以挂载到一个实际的 DOM 元素。

    js
    app.mount(document.body.firstChild)

app.unmount() ​

卸载一个已挂载的应用实例。卸载一个应用会触发该应用组件树内所有组件的卸载生命周期钩子。

  • 类型

    ts
    interface App { unmount(): void}

app.component() ​

如果同时传递一个组件名字符串及其定义,则注册一个全局组件;如果只传递一个名字,则会返回用该名字注册的组件 (如果存在的话)。

  • 类型

    ts
    interface App { component(name: string): Component | undefined component(name: string, component: Component): this}
  • 示例

    js
    import { createApp } from 'vue'const app = createApp({})// 注册一个选项对象app.component('my-component', { /* ... */})// 得到一个已注册的组件const MyComponent = app.component('my-component')
  • 参考组件注册

app.directive() ​

如果同时传递一个名字和一个指令定义,则注册一个全局指令;如果只传递一个名字,则会返回用该名字注册的指令 (如果存在的话)。

  • 类型

    ts
    interface App { directive(name: string): Directive | undefined directive(name: string, directive: Directive): this}
  • 示例

    js
    import { createApp } from 'vue'const app = createApp({ /* ... */})// 注册(对象形式的指令)app.directive('my-directive', { /* 自定义指令钩子 */})// 注册(函数形式的指令)app.directive('my-directive', () => { /* ... */})// 得到一个已注册的指令const myDirective = app.directive('my-directive')
  • 参考自定义指令

app.use() ​

安装一个插件。

  • 类型

    ts
    interface App { use(plugin: Plugin, ...options: any[]): this}
  • 详细信息

    第一个参数应是插件本身,可选的第二个参数是要传递给插件的选项。

    插件可以是一个带 install() 方法的对象,亦或直接是一个将被用作 install() 方法的函数。插件选项 (app.use() 的第二个参数) 将会传递给插件的 install() 方法。

    app.use() 对同一个插件多次调用,该插件只会被安装一次。

  • 示例

    js
    import { createApp } from 'vue'import MyPlugin from './plugins/MyPlugin'const app = createApp({ /* ... */})app.use(MyPlugin)
  • 参考插件

app.mixin() ​

应用一个全局 mixin (适用于该应用的范围)。一个全局的 mixin 会作用于应用中的每个组件实例。

不推荐

Mixins 在 Vue 3 支持主要是为了向后兼容,因为生态中有许多库使用到。在新的应用中应尽量避免使用 mixin,特别是全局 mixin。

若要进行逻辑复用,推荐用组合式函数来替代。

  • 类型

    ts
    interface App { mixin(mixin: ComponentOptions): this}

app.provide() ​

提供一个值,可以在应用中的所有后代组件中注入使用。

  • 类型

    ts
    interface App { provide(key: InjectionKey | symbol | string, value: T): this}
  • 详细信息

    第一个参数应当是注入的 key,第二个参数则是提供的值。返回应用实例本身。

  • 示例

    js
    import { createApp } from 'vue'const app = createApp(/* ... */)app.provide('message', 'hello')

    在应用的某个组件中:

    js
    import { inject } from 'vue'export default { setup() { console.log(inject('message')) // 'hello' }}
    js
    export default { inject: ['message'], created() { console.log(this.message) // 'hello' }}
  • 参考

    • 依赖注入
    • 应用层 Provide
    • app.runWithContext()

app.runWithContext() {#app-runwithcontext}"">​

使用当前应用作为注入上下文执行回调函数。

  • 类型

    ts
    interface App { runWithContext(fn: () => T): T}
  • 详情

    需要一个回调函数并立即运行该回调。在回调同步调用期间,即使没有当前活动的组件实例,inject() 调用也可以从当前应用提供的值中查找注入。回调的返回值也将被返回。

  • 示例

    js
    import { inject } from 'vue'app.provide('id', 1)const injected = app.runWithContext(() => { return inject('id')})console.log(injected) // 1

app.version ​

提供当前应用所使用的 Vue 版本号。这在插件中很有用,因为可能需要根据不同的 Vue 版本执行不同的逻辑。

  • 类型

    ts
    interface App { version: string}
  • 示例

    在一个插件中对版本作判断:

    js
    export default { install(app) { const version = Number(app.version.split('.')[0]) if (version  void}
  • 详细信息

    错误处理器接收三个参数:错误对象、触发该错误的组件实例和一个指出错误来源类型信息的字符串。

    它可以从下面这些来源中捕获错误:

    • 组件渲染器
    • 事件处理器
    • 生命周期钩子
    • setup() 函数
    • 侦听器
    • 自定义指令钩子
    • 过渡 (Transition) 钩子
  • 示例

    js
    app.config.errorHandler = (err, instance, info) => { // 处理错误,例如:报告给一个服务}

app.config.warnHandler ​

用于为 Vue 的运行时警告指定一个自定义处理函数。

  • 类型

    ts
    interface AppConfig { warnHandler?: ( msg: string, instance: ComponentPublicInstance | null, trace: string ) => void}
  • 详细信息

    警告处理器将接受警告信息作为其第一个参数,来源组件实例为第二个参数,以及组件追踪字符串作为第三个参数。

    这可以用户过滤筛选特定的警告信息,降低控制台输出的冗余。所有的 Vue 警告都需要在开发阶段得到解决,因此仅建议在调试期间选取部分特定警告,并且应该在调试完成之后立刻移除。

    TIP

    警告仅会在开发阶段显示,因此在生产环境中,这条配置将被忽略。

  • 示例

    js
    app.config.warnHandler = (msg, instance, trace) => { // `trace` 是组件层级结构的追踪}

app.config.performance ​

设置此项为 true 可以在浏览器开发工具的“性能/时间线”页中启用对组件初始化、编译、渲染和修补的性能表现追踪。仅在开发模式和支持 performance.mark API 的浏览器中工作。

  • 类型boolean

  • 参考指南 - 性能

app.config.compilerOptions ​

配置运行时编译器的选项。设置在此对象上的值将会在浏览器内进行模板编译时使用,并会影响到所配置应用的所有组件。另外你也可以通过 compilerOptions 选项在每个组件的基础上覆盖这些选项。

重要

此配置项仅在完整构建版本,即可以在浏览器中编译模板的 vue.js 文件中可用。如果你用的是带构建的项目配置,且使用的是仅含运行时的 Vue 文件版本,那么编译器选项必须通过构建工具的相关配置传递给 @vue/compiler-dom

  • vue-loader:通过 compilerOptions loader 的选项传递。并请阅读如何在 vue-cli 中配置它。

  • vite:通过 @vitejs/plugin-vue 的选项传递。

app.config.compilerOptions.isCustomElement ​

用于指定一个检查方法来识别原生自定义元素。

  • 类型 (tag: string) => boolean

  • 详细信息

    如果该标签需要当作原生自定义元素则应返回 true。对匹配到的标签,Vue 会将其渲染为原生元素而非将其视为一个 Vue 组件来解析。

    原生 HTML 和 SVG 标签不需要在此函数中进行匹配,Vue 的解析器会自动识别它们。

  • 示例

    js
    // 将所有标签前缀为 `ion-` 的标签视为自定义元素app.config.compilerOptions.isCustomElement = (tag) => { return tag.startsWith('ion-')}
  • 参考 Vue 与 Web Components

app.config.compilerOptions.whitespace ​

用于调整模板中空格的处理行为。

  • 类型 'condense' | 'preserve'

  • 默认 'condense'

  • 详细信息

    Vue 移除/缩短了模板中的空格以求更高效的模板输出。默认的策略是“缩短”,表现行为如下:

    1. 元素中开头和结尾的空格字符将被缩短为一个空格。
    2. 包含换行的元素之间的空白字符会被删除。
    3. 文本节点中连续的空白字符被缩短成一个空格。

    设置该选项为 'preserve' 则会禁用 (2) 和 (3) 两项。

  • 示例

    js
    app.config.compilerOptions.whitespace = 'preserve'

app.config.compilerOptions.delimiters ​

用于调整模板内文本插值的分隔符。

  • 类型 [string, string]

  • 默认 ['{{', '}}']

  • 详细信息

    此项通常是为了避免与同样使用 mustache 语法的服务器端框架发生冲突。

  • 示例

    js
    // 分隔符改为ES6模板字符串样式app.config.compilerOptions.delimiters = ['${', '}']

app.config.compilerOptions.comments ​

用于调整是否移除模板中的 HTML 注释。

  • 类型 boolean

  • 默认 false

  • 详细信息

    默认情况下,Vue 会在生产环境移除所有注释,设置该项为 true 会强制 Vue 在生产环境也保留注释。在开发过程中,注释是始终被保留的。这个选项通常在 Vue 与其他依赖 HTML 注释的库一起使用时使用。

  • 示例

    js
    app.config.compilerOptions.comments = true

app.config.globalProperties ​

一个用于注册能够被应用内所有组件实例访问到的全局属性的对象。

  • 类型

    ts
    interface AppConfig { globalProperties: Record}
  • 详细信息

    这是对 Vue 2 中 Vue.prototype 使用方式的一种替代,此写法在 Vue 3 已经不存在了。与任何全局的东西一样,应该谨慎使用。

    如果全局属性与组件自己的属性冲突,组件自己的属性将具有更高的优先级。

  • 用法

    js
    app.config.globalProperties.msg = 'hello'

    这使得 msg 在应用的任意组件模板上都可用,并且也可以通过任意组件实例的 this 访问到:

    js
    export default { mounted() { console.log(this.msg) // 'hello' }}
  • 参考指南 - 扩展全局属性

app.config.optionMergeStrategies ​

一个用于定义自定义组件选项的合并策略的对象。

  • 类型

    ts
    interface AppConfig { optionMergeStrategies: Record}type OptionMergeFunction = (to: unknown, from: unknown) => any
  • 详细信息

    一些插件或库对自定义组件选项添加了支持 (通过注入全局 mixin)。这些选项在有多个不同来源时可能需要特殊的合并策略 (例如 mixin 或组件继承)。

    可以在 app.config.optionMergeStrategies 对象上以选项的名称作为 key,可以为一个自定义选项注册分配一个合并策略函数。

    合并策略函数分别接受在父实例和子实例上定义的该选项的值作为第一和第二个参数。

  • 示例

    js
    const app = createApp({ // 自身的选项 msg: 'Vue', // 来自 mixin 的选项 mixins: [ { msg: 'Hello ' } ], mounted() { // 在 this.$options 上暴露被合并的选项 console.log(this.$options.msg) }})// 为 `msg` 定义一个合并策略函数app.config.optionMergeStrategies.msg = (parent, child) => { return (parent || '') + (child || '')}app.mount('#app')// 打印 'Hello Vue'
  • 参考组件实例 - $options

鹏仔微信 15129739599 鹏仔QQ344225443 鹏仔前端 pjxi.com 共享博客 sharedbk.com

免责声明:我们致力于保护作者版权,注重分享,当前被刊用文章因无法核实真实出处,未能及时与作者取得联系,或有版权异议的,请联系管理员,我们会立即处理! 部分文章是来自自研大数据AI进行生成,内容摘自(百度百科,百度知道,头条百科,中国民法典,刑法,牛津词典,新华词典,汉语词典,国家院校,科普平台)等数据,内容仅供学习参考,不准确地方联系删除处理!邮箱:344225443@qq.com)

图片声明:本站部分配图来自网络。本站只作为美观性配图使用,无任何非法侵犯第三方意图,一切解释权归图片著作权方,本站不承担任何责任。如有恶意碰瓷者,必当奉陪到底严惩不贷!

内容声明:本文中引用的各种信息及资料(包括但不限于文字、数据、图表及超链接等)均来源于该信息及资料的相关主体(包括但不限于公司、媒体、协会等机构)的官方网站或公开发表的信息。部分内容参考包括:(百度百科,百度知道,头条百科,中国民法典,刑法,牛津词典,新华词典,汉语词典,国家院校,科普平台)等数据,内容仅供参考使用,不准确地方联系删除处理!本站为非盈利性质站点,本着为中国教育事业出一份力,发布内容不收取任何费用也不接任何广告!)