跳到主要内容
版本:v8

Vue 构建选项

Vue 提供了多种工具来微调您的应用程序。本指南涵盖了与 Ionic Framework 最相关的构建选项。

组件注册策略

局部组件注册(推荐)

默认情况下,Ionic Framework 组件采用局部注册方式。通过局部注册,这些组件会被导入并提供给每个需要使用它们的 Vue 组件。这是推荐的做法,因为它允许懒加载和树摇优化对 Ionic Framework 组件正常工作。

这种方法的唯一缺点是可能需要多次重复导入 Ionic Framework 组件,略显繁琐。但我们认为,由此带来的性能优势是值得的。

同时请注意,局部注册的组件在子组件中不可用。您需要在子组件中重新导入要使用的 Ionic Framework 组件。

让我们看看局部组件注册是如何工作的:

<template>
<ion-page>
<ion-content>
<SubComponent></SubComponent>
</ion-content>
</ion-page>
</template>

<script setup lang="ts">
import { IonContent, IonPage } from '@ionic/vue';
import SubComponent from '@/components/SubComponent.vue';
</script>

在上面的示例中,我们使用了 IonPageIonContent 组件。为了使用它们,我们从 @ionic/vue 导入这些组件。然后,就可以在模板中使用这些组件。

请注意,由于我们是在局部注册这些组件,IonPageIonContentSubComponent 中都将不可用,除非我们也在那里注册它们。

更多信息,请参阅 Vue 局部注册文档

全局组件注册

另一种注册组件的方式是使用全局注册。全局注册涉及在 main.ts 中导入要使用的组件,并在 Vue 应用实例上调用 component 方法。

虽然这可以更轻松地将 Ionic Framework 组件添加到您的 Vue 应用中,但全局注册通常并不理想。引用 Vue 文档中的话:"如果你使用像 Webpack 这样的构建系统,全局注册所有组件意味着即使你停止使用某个组件,它仍可能包含在最终构建中。这会不必要地增加用户必须下载的 JavaScript 文件大小"。

让我们看看全局组件注册是如何工作的:

main.ts

import { IonContent, IonicVue, IonPage } from '@ionic/vue';

const app = createApp(App).use(IonicVue).use(router);

app.component('ion-content', IonContent);
app.component('ion-page', IonPage);

MyComponent.vue

<template>
<ion-page>
<ion-content>
<SubComponent></SubComponent>
</ion-content>
</ion-page>
</template>

<script setup lang="ts">
import SubComponent from '@/components/SubComponent.vue';
</script>

在上面的示例中,我们使用了 IonPageIonContent 组件。为了使用它们,我们首先在 main.ts 中从 @ionic/vue 导入这些组件。然后,我们在应用实例上调用 component 方法,并传递标签名和组件定义。完成此操作后,我们就可以在应用程序的其余部分使用这些组件,而无需在每个 Vue 组件中导入它们。

更多信息,请参阅 Vue 全局注册文档

构建优化

预取应用程序 JavaScript

默认情况下,Vue CLI 会自动为应用程序中的 JavaScript 生成预取提示。预取功能利用浏览器空闲时间下载用户可能在近期访问的文档。当用户访问需要预取文档的页面时,可以从浏览器缓存中快速提供。

预取会消耗带宽,因此如果您的应用较大,可能需要禁用它。您可以通过修改或创建 vue.config.js 文件来实现:

vue.config.js

module.exports = {
chainWebpack: (config) => {
config.plugins.delete('prefetch');
},
};

上述配置将防止所有文件被预取,而是在需要时加载它们。您也可以选择预取某些代码块。更多示例请查看 Vue CLI 预取文档