要素テーブルの多層ネスト表示の実践

要素テーブルの多層ネスト表示の実践

複数の注文を含むリストが必要です。各注文は一意にすることも、複数の注文を結合することもできます。各注文の下に別のテーブルが表示されます。上の図を参照してください。

各行の動作は異なり、マージコードは公式サイトでいくつかの例を通してまとめられています。

<テンプレート>
  <div class="アプリコンテナ">
    <div>
      <el-テーブル
        :data="テーブルデータ"
        スタイル="幅: 100%;マージン下部: 20px;"
        :span-method="配列スパンメソッド"
        行キー="id"
        国境
      >
        <el-table-column type="expand">
          <テンプレート スロット スコープ="props">
            <el-テーブル
              クラス="テーブル内テーブル"
              :show-header="false"
              :data="props.row.datas"
              スタイル="幅: 100%;"
              行キー="id"
              :span-method="配列スパンメソッド"
              国境
            >
              <el-table-column type="expand">
                <テンプレート スロット スコープ="props">
                  <el-テーブル
                    クラス="テーブル内テーブル"
                    :data="props.row.datas"
                    スタイル="幅: 100%;"
                    行キー="id"
                    国境
                  >
                    <el-table-column prop="date" label="注文日" width="180"></el-table-column>
                    <el-table-column prop="type" label="ドキュメントタイプ" width="180"></el-table-column>
                    <el-table-column prop="ステータス" label="ステータス"></el-table-column>
                    <el-table-column label="操作" width="120">
                      <テンプレート スロット スコープ="props">
                        <el-button type="text" size="small">削除</el-button>
                      </テンプレート>
                    </el-table-column>
                  </el-table>
                </テンプレート>
              </el-table-column>
              <el-table-column prop="applyNo" label="申請番号" width="132.2"></el-table-column>
              <el-table-column prop="name" label="姓名" width="180"></el-table-column>
              <el-table-column prop="address" label="住所"></el-table-column>
            </el-table>
          </テンプレート>
        </el-table-column>
        <el-table-column prop="applyNo" label="申請番号" width="180"></el-table-column>
        <el-table-column prop="name" label="姓名" width="180"></el-table-column>
        <el-table-column prop="address" label="住所"></el-table-column>
        <el-table-column label="操作" width="120">
          <テンプレート スロット スコープ="props">
            <el-button type="text" size="small">削除</el-button>
          </テンプレート>
        </el-table-column>
      </el-table>
    </div>
  </div>
</テンプレート>
 
<スクリプト>
エクスポートデフォルト{
  名前: "name1",
  コンポーネント: {},
  データ() {
    戻る {
      テーブルデータ: [
        {
          id: 1,
          申請番号: "202004291234",
          名前:「李思」
          住所:「上海市普陀区金沙江路1518号」
        },
        {
          id: 2,
          申請番号: "202004291235",
          名前:「張三」
          住所:「上海市普陀区金沙江路1517号」
        },
        {
          id: 3,
          適用番号: "202004291236,202004291237",
          名前: 「王武」、
          住所:「上海市普陀区金沙江路1519号」
          データ: [
            {
              id: 31,
              申請番号: "202004291236",
              名前: 「王武」、
              住所:「上海市普陀区金沙江路1519号」
              データ: [
                {
                  id: 31,
                  日付: "2016-05-01",
                  タイプ: "タイプ1",
                  ステータス: 「発送済み」
                },
                {
                  id: 32,
                  日付: "2016-05-01",
                  タイプ: "タイプ2",
                  ステータス: 「未発送」
                }
              ]
            },
            {
              id: 32,
              申請番号: "202004291237",
              名前: 「王武」、
              住所:「上海市普陀区金沙江路1519号」
            }
          ]
        },
        {
          id: 4,
          申請番号: "202004291238",
          名前: "赵6六",
          住所:「上海市普陀区金沙江路1516号」
        }
      ]
    };
  },
  メソッド: {
    配列スパンメソッド({ 行、列、行インデックス、列インデックス }) {
      if (!row.datas) {
        列インデックス === 0 の場合 {
          [0, 0]を返します。
        } そうでない場合 (列インデックス === 1) {
          [1, 2]を返します。
        }
      }
    }
  }
};
</スクリプト>
<style lang="scss" スコープ>
.app-コンテナ{
  ::v-ディープ{
    .el-table th {
      背景: #ddeeff;
    }
    .el-table__展開セル{
      下境界線: 0px;
      右境界線: 0px;
      パディング: 0px 0px 0px 47px;
    }
  }
  .テーブルインテーブル {
    上境界線: 0px;
  }
}
</スタイル>

注意: ここで注意すべき点は、公式のデフォルトが children であるため、子ノードはchildren を使用できないことです。そのため、他のドロップダウンコンポーネントが td 幅を設定する場合、内側のレイヤーと外側のレイヤーの差は 47.8 であることに注意してください。

要素テーブルの多層ネスト表示の実践に関するこの記事はこれで終わりです。多層ネスト要素テーブルに関するより関連性の高いコンテンツについては、123WORDPRESS.COM の以前の記事を検索するか、以下の関連記事を引き続き参照してください。今後とも 123WORDPRESS.COM をよろしくお願いいたします。

以下もご興味があるかもしれません:
  • ElementUI のネストされたテーブルに基づいて複数選択を実装するためのサンプル コード

<<:  MySQL 5.5 の導入に関する問題

>>:  CentOS7 で docker を使用して Apollo 構成センターをデプロイする実装

推薦する

HTMLは実際にはいくつかの重要なタグを学ぶアプリケーションです

「これは革命になるだろう」という記事が出たあと。業界の皆様に認知され、もちろん内外からの評価もいただ...

MySQL インデックス プッシュダウンの詳細

目次1. 左端接頭辞原則2. 表に戻る3. インデックスプッシュダウン序文:インデックス プッシュダ...

docker run 起動パラメータ コマンドを表示する方法 (推奨)

runlike を使用してコンテナの docker run 起動パラメータを表示します。 pipを...

bitronix を使用して MySQL に接続するときの MySQLSyntaxErrorException の解決方法

bitronix を使用して MySQL に接続するときの MySQLSyntaxErrorExce...

HTML テーブル マウス ドラッグ ソート機能

効果画像: 1. ファイルをインポートする<script src="js/jquer...

VirtualBox を使用して Linux クラスターをシミュレートする方法

1. ホストMacbookにHOSTをセットアップする前回のドキュメントでは仮想マシンの静的 IP ...

シンプルなカレンダー効果を実現する js

この記事では、シンプルなカレンダー効果を実現するためのjsの具体的なコードを参考までに共有します。具...

MySQL DML言語操作例

追加説明、外部キー: 外部キーを使用しないでください。すべての外部キーの概念はアプリケーション層で解...

jwtを使用してノードによって生成されたトークンをどこに保存するかについての簡単な説明

A: 通常はクライアントに保存されます。 jwt または JSON Web Token は、リクエス...

Vueフロントエンドの効率的な開発のためのレンダリング手順をリストします

v-for ディレクティブリストといえば、ループについても触れなければなりません。v-for 命令は...

MySQL ログイン エラーを解決する: 'ユーザー 'root'@'localhost' へのアクセスが拒否されました

まず、コマンドラインまたはワークベンチを使用して MySQL にログインできず、「ユーザー '...

altとtitleの違いの詳しい説明

これら 2 つの属性はよく使用されますが、その違いはまとめられていません。それでは、その使い方をまと...

Nginxでネットワーク分離を解決した実践記録を詳しく解説

必要最近、Node オンライン サービスを移行する必要があったため、2 つの新しいオンライン サーバ...

JavaScript演算子の使用に関するヒントをいくつか共有します

目次1. オプションの連鎖演算子 [? .】 2. 論理的な空の代入 (?? =) 3. 論理和代入...

calc() で全画面背景の固定幅コンテンツを実現

ここ数年、Web デザインには「全幅背景と固定幅コンテンツ」というトレンドが生まれています。このデザ...