Vueはカスタムツリーコンポーネントを再帰的に実装します

Vueはカスタムツリーコンポーネントを再帰的に実装します

この記事では、カスタムツリーコンポーネントを再帰的に実装する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 を応援していただければ幸いです。

以下もご興味があるかもしれません:
  • Vueのツリーコンポーネントを実装する方法
  • vueでvant TreeSelect分類選択コンポーネント操作を使用する
  • Vue は zTree プラグインを使用してツリーコンポーネント操作の例をカプセル化します。
  • Vue 再帰コンポーネント + Vuex 開発ツリーコンポーネント ツリー - 再帰コンポーネントのシンプルな実装
  • Vueコンポーネントツリーはツリーメニューを実装します
  • Vue2 コンポーネントツリーは無制限レベルのツリーメニューを実装します
  • Vue.js コンポーネントツリーは、州と都市間の多階層の連携を実現します
  • Vue.js コンポーネント ツリーは無制限レベルのツリー メニューを実装します

<<:  LinuxスレッドのPID(TID、LWP)を取得するいくつかの方法の詳細な説明

>>:  MySQL外部キーの3つの関係例の詳細な説明

推薦する

MySQL 8.0.11 のインストールと設定方法のグラフィックチュートリアル MySQL 8.0 の新しいパスワード認証方法

この記事では、参考までにMySQL8.0.11のインストールと設定方法、およびMySQL8.0の新し...

Docker MySQLコンテナデータベースへの変更が有効にならない問題を解決する

公式の MySQL イメージを使用するには、構成ファイル、DB データ ファイル ディレクトリなどの...

LeetCode の SQL 実装 (181. 従業員は管理職よりも収入が高い)

[LeetCode] 181.従業員の収入が管理職よりも多い従業員テーブルには、マネージャーを含む...

uniapp プロジェクトの最適化方法と提案

目次1. 複雑なページデータ領域をコンポーネントにカプセル化する2. 大きな画像の使用を避ける3. ...

Java は Excel から MySQL にデータをインポートします

実際の業務では、Excel からデータベースにデータをインポートする必要がある場合があります。データ...

Docker Secretの管理と使用の詳細な説明

1. Docker Secretとは1. シナリオ表示MySQL サービスなど、一部のサービスではパ...

MySQL メタデータで Hive テーブル作成ステートメントのコメント スクリプトを生成する方法

序文この記事は主にMySQLメタデータ生成Hiveテーブル作成ステートメントコメントスクリプトに関す...

アイデア展開Tomcatサービス実装プロセス図

まずプロジェクトの成果物を構成するスタートアップ項目の設定 Tomcatサービスを作成する開始したい...

HTML テーブル マークアップ チュートリアル (1): テーブルの作成

<br />これは 123WORDPRESS.COM が提供する一連のチュートリアルです...

MySQL InnoDB のロック機構の詳細な説明

前面に書かれたデータベースは本質的に共有リソースであるため、同時アクセスのパフォーマンスを最大化する...

Alibaba Cloud Nginx はドメイン名アクセス プロジェクトを実装するために https を設定します (グラフィック チュートリアル)

ステップ1: サードパーティの信頼できるSSL証明書に署名するAlibaba Cloud で直接、無...

MySQL列挙型のテスト例

プロジェクトを開発しているとき、支払い済み、支払済み、クローズ済み、返金済みなどの注文ステータスなど...

マルチポートおよびマルチドメイン名アクセスのNginx構成の実装

サーバーに複数のサイトを展開するには、異なるサイトにアクセスするために複数のポートを開く必要がありま...

レアタグフィールドセットと凡例の使用方法の詳細な説明

<fieldset>と<legend>については、ほとんどの人はおそらく馴染...

MySQLの再帰問題

MySQL自体は再帰構文をサポートしていませんが、自己接続を通じていくつかの単純な再帰を実現できます...