JavaScript フレームワークを使用して大規模なアプリケーションを作成する場合は、コンポーネントの構造を考慮することが重要です。コンポーネントの構造を考慮することで、実行時に各コンポーネントが読み込まれてアプリケーションの速度が低下することを回避できます。アプリケーションを構築するときに、不要なデータをユーザーに返したり、全体的にユーザー エクスペリエンスが低下したりすることを回避することもできます。
React や Angular などのフレームワークは、コンポーネント構造を考慮するためにそれぞれ React.lazy()
とルーティング モデルを使用します。
この記事では、2 つのデモを実装して、Vue が非同期コンポーネントを使用して、遅延読み込みとコード分割手法を使用してアプリケーションの読み込み時間を短縮する方法を確認します。
Vue でのコンポーネントの作成
Vue がどのように機能するかを理解するために、基本的なコンポーネントを作成することから始めましょう。
ターミナルに移動し、Vue の CLI をインストールし、プロジェクトを作成します。
npm install -g vue/cli vue create book-project #choose the default setting when prompted
新しいプロジェクト フォルダーで、helloworld.vue を含むデフォルト ファイルの内容を置き換えましょう。
と app.vue
。まずは書籍の寄付ページを作成します。 helloworld.vue
の名前を book.vue
に変更し、その内容を次の内容に置き換えます:
<!--Book.vue--> <template> <h1>Donate Books</h1> </template>
次に、App を次の内容に置き換えます。
:
<!--App.vue--> <template> <div> <book></book> </div> </template> <script> Import Book from "./components/Book" export default { components: { Book } } </script> <style> #app { font-family: 'Avenir', Helvetica, Arial, sans-serif; -webkit-font-smoothing: antialiased; -moz-osx-font-smoothing: grayscale; text-align: center; color: #2c3e50; margin-top: 60px; } </style>
上記のコード ブロックでは、Book
コンポーネントが静的にインポートされていることがわかります。これは、アプリケーションがロードされるたびに Book
コンポーネントがロードされることを意味します。
次に、ターミナルで npm runserve
を実行し、localhost:8080
に移動して、基本コンポーネントを表示します。
#アプリケーションがロードされるたびに
Book コンポーネントをロードしても、重大なパフォーマンス上の問題はないようです。ただし、アプリケーションが大きくなるにつれて、実行時に各コンポーネントをロードするのは面倒になります。
// dynamic import import("./components/Book").then(Book => { // Insert the Book module here });
<template> <div> <book></book> </div> </template> <script> export default { components: { Book: () => import("./components/Book") } }; </script>
import() 関数は
Book コンポーネントを返します。これにより、非同期で読み込むことができます。ブラウザ
devtools の [ネットワーク] タブを見ると、
App.js によって開始された
0.js という名前のファイルがあります。このファイルには、非同期コンポーネントが含まれています:
非同期コンポーネントを使用して Vue アプリケーションを作成する
続けてみましょう基本的な書籍寄付アプリケーションを構築して、非同期コンポーネントを活用する方法を示します。最後に、ユーザーがDonate ボタンをクリックしたときにのみ
Donate コンポーネントが読み込まれるようにします。
vue-material をインストールしましょう。アプリケーションにはこのスタイルを使用します:
cd book-project npm i vue-material
vue-material をアプリケーションにインクルードし、
src/main.js:
にインポートします。
import Vue from 'vue' import App from './App.vue' Vue.config.productionTip = false import VueMaterial from 'vue-material' import 'vue-material/dist/vue-material.min.css' import 'vue-material/dist/theme/default.css' Vue.use(VueMaterial) new Vue({ render: h => h(App), }).$mount('#app')
Book コンポーネントを構築しましょう。
<!--Book.vue--> <template> <div id="app"> <md-card md-with-hover v-for="(book, key) in books" v-bind:key="key"> <md-ripple> <md-card-header> <div class="md-title">{{book.name}}</div> <div class="md-subhead">{{book.genre}}</div> </md-card-header> <md-card-actions> <md-button type="primary" @click="addBook(key)">Donate to improve {{book.genre}}</md-button> </md-card-actions> </md-ripple> </md-card> <div v-if="show"> <md-card-content> <donate v-bind:selectList="selectList"></donate> </md-card-content> </div> <md-button @click="show = true" id="donate">Donate {{selectList.length}} book(s)</md-button> </div> </template> <script> export default { name: 'RegularButtons', methods: { addBook (key) { if(!this.selectList.includes(key)) { this.selectList.push(key); } } }, components: { donate: () => import('./Donate') }, data: () => ({ books: [ { name: 'Using Creatine', genre: 'Workouts' }, { name: 'Learn Parkour', genre: 'Sports' }, { name: 'Snorkelling', genre: 'Diving' }, ], selectList: [], show: false }) } </script>
addBook() メソッドが選択した書籍を
selectList 配列にプッシュし、寄贈された書籍の総数を表示します。
show は
true に設定されます。これにより、
v-if ステートメントで、選択した書籍の数を含む
donate コンポーネントを表示できるようになります。
donate コンポーネントは、