この記事では、カスタムツリーコンポーネントを再帰的に実装するVueの具体的なコードを参考までに共有します。具体的な内容は次のとおりです。 1. tree/index.vue 内: <テンプレート> <div> <ul> <item :model='データ'></item> </ul> </div> </テンプレート> <スクリプト> './item' からアイテムをインポートします エクスポートデフォルト{ コンポーネント:{ アイテム }, データ(){ 戻る { データ:{ タイトル:"レベル 1", 子供たち:[ { タイトル:"レベル 1-1", 子供たち:[ { タイトル:"レベル 3 1-1-1", 子供たち:[ { タイトル:「レベル4 1-1-1-1」、 子供たち:[ { タイトル:"レベル 5 1-1-1-1-1" } ] } ] } ] },{ タイトル:「レベル1-2」、 子供たち:[ { タイトル:「レベル3 1-2-1」 } ] } ] } } } } </スクリプト> 2. item.vue コンポーネント: <テンプレート> <li> <div @click="トグル"> {{モデル.タイトル}} <span v-if="isFolder">[{{open?'-':'+'}}]</span> </div> <ul v-show="開く" v-if="isFolder"> <item v-for="(child,index) in model.children" :model='child' :key='index'></item> </ul> </li> </テンプレート> <スクリプト> エクスポートデフォルト{ 名前:'アイテム', 小道具:{ モデル:{ タイプ:オブジェクト、 必須:true } }, データ(){ 戻る { 開く:false } }, 計算:{ フォルダ(){ this.model.children を返す && this.model.children.length>0 } }, 方法:{ トグル(){ if (this.isFolder) this.open =!this.open } } } </スクリプト> 3. 任意のコンポーネントでの使用: <テンプレート> <div class="index"> <木></木> </div> </テンプレート> <スクリプト> 「@/components/tree」から Tree をインポートします。 コンポーネント:{ 木 } </スクリプト> 以上がこの記事の全内容です。皆様の勉強のお役に立てれば幸いです。また、123WORDPRESS.COM を応援していただければ幸いです。 以下もご興味があるかもしれません:
|
<<: LinuxスレッドのPID(TID、LWP)を取得するいくつかの方法の詳細な説明
この記事では、参考までにMySQL8.0.11のインストールと設定方法、およびMySQL8.0の新し...
公式の MySQL イメージを使用するには、構成ファイル、DB データ ファイル ディレクトリなどの...
[LeetCode] 181.従業員の収入が管理職よりも多い従業員テーブルには、マネージャーを含む...
目次1. 複雑なページデータ領域をコンポーネントにカプセル化する2. 大きな画像の使用を避ける3. ...
実際の業務では、Excel からデータベースにデータをインポートする必要がある場合があります。データ...
1. Docker Secretとは1. シナリオ表示MySQL サービスなど、一部のサービスではパ...
序文この記事は主にMySQLメタデータ生成Hiveテーブル作成ステートメントコメントスクリプトに関す...
まずプロジェクトの成果物を構成するスタートアップ項目の設定 Tomcatサービスを作成する開始したい...
<br />これは 123WORDPRESS.COM が提供する一連のチュートリアルです...
前面に書かれたデータベースは本質的に共有リソースであるため、同時アクセスのパフォーマンスを最大化する...
ステップ1: サードパーティの信頼できるSSL証明書に署名するAlibaba Cloud で直接、無...
プロジェクトを開発しているとき、支払い済み、支払済み、クローズ済み、返金済みなどの注文ステータスなど...
サーバーに複数のサイトを展開するには、異なるサイトにアクセスするために複数のポートを開く必要がありま...
<fieldset>と<legend>については、ほとんどの人はおそらく馴染...
MySQL自体は再帰構文をサポートしていませんが、自己接続を通じていくつかの単純な再帰を実現できます...