ホームページ >ウェブフロントエンド >Vue.js >vue3 を使用してコンポーネントを動的にロードし、コンポーネントを動的に導入する方法

vue3 を使用してコンポーネントを動的にロードし、コンポーネントを動的に導入する方法

王林
王林転載
2023-05-11 12:01:143563ブラウズ

1. 問題

vite で構築された vue3 プロジェクトで作業する場合、.vue ページを動的にプルしてインポートし、その後、コンソールに次のプロンプトが表示され続け、ページをレンダリングできません。

vue3 を使用してコンポーネントを動的にロードし、コンポーネントを動的に導入する方法

2. 分析

上記のエラー メッセージに従って、@rollup/plugin-dynamic-import-vars をインストールして使用してみましょう。 このプラグイン (結局そのような解決策はありません)。

Vite 公式ドキュメントには、 Glob インポート フォーム を使用する必要があると記載されており、Glob ドキュメントを読んでこの問題を解決しました (個人テストは可能です)。

最初に、特別な import.meta.glob 関数を使用して、ファイル システムから複数のモジュールをインポートする必要があります。

const modules = import.meta.glob('../views/*/*.vue');

彼は、すべての関連コンポーネントを照合してインポートします。

// vite 生成的代码
const modules = {
  './views/foo.vue': () => import('./views/foo.vue'),
  './views/bar.vue': () => import('./views/bar.vue')
}

次に、プロジェクトに戻り、custom_components フォルダー内のすべての home の下の index.vue ファイルにインポートします。フォルダー .vueFile

vue3 を使用してコンポーネントを動的にロードし、コンポーネントを動的に導入する方法

したがって、vite の import.meta.glob 関数に従って、対応する custom_components# を取得できます。 ##.vueフォルダ下のファイル

const changeComponents = (e:string)=>{
	const link = modules[`../custom_components/${e}.vue`]
	console.log(link,'link')
}

Print

link

vue3 を使用してコンポーネントを動的にロードし、コンポーネントを動的に導入する方法#ようやく確認できます非同期 コンポーネントの登録

layouts.value = markRaw(defineAsyncComponent(link))

3.最後に

完全なケースを参考のために以下に掲載します。もっと良いものがある場合、または最適化が必要な場合は、質問して一緒に話し合うことができます。

rree

以上がvue3 を使用してコンポーネントを動的にロードし、コンポーネントを動的に導入する方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事はyisu.comで複製されています。侵害がある場合は、admin@php.cn までご連絡ください。