vue+element テーブルで動的な列フィルタリングを実装するためのサンプルコード

vue+element テーブルで動的な列フィルタリングを実装するためのサンプルコード

要件: データをリスト形式で表示する場合、表示すべき情報項目が多く、表が横に長くなってしまいます。表示が明確でなく、使用時に要点が掴めないと感じる場合があります。

次のような実装を想像してください。ユーザーはテーブルの列を非表示にするか表示するかを手動で選択し、ユーザーの選択ステータスが記録され、ユーザーが次にテーブルに入ったときに選択ステータスが保持されます。

効果図は以下のとおりです。

オリジナル:

ここに画像の説明を挿入

必要ない場合はデフォルトのチェックを外します。

ここに画像の説明を挿入

実装コード:
HTML 部分では、複数選択ボックス コンポーネントを使用して列オプションを表示し、 v-if="colData[i].istrue"を使用して表示と非表示を制御します。列オプションはチェックボックスに渡され、チェック イベントがバインドされます。

<el-popover placement="right" title="列フィルター" trigger="click" width="420">            
	<el-checkbox-group v-model="checkedColumns" size="mini">
		<el-checkbox v-for="checkBoxGroup 内の項目" :key="項目" :label="項目" :value="項目"></el-checkbox>
	</el-チェックボックスグループ>
	<el-button slot="reference" type="primary" size="small" plain><i class="el-icon-arrow-down el-icon-menu" />リスト項目表示フィルター</el-button>
</el-popover>
<el-table :data="attendanceList" @sort-change="sort" highlight-current-row :row-class-name="holidayRow" @selection-change="editAll" ref="multipleTable">
	<el-table-column type="selection" width="55" align="center"></el-table-column>
		<el-table-column label="従業員の基本情報">
		<el-table-column v-if="colData[0].istrue" align="center" prop="user_id" label="作品番号。" width="80" 固定></el-table-column>
		<el-table-column v-if="colData[1].istrue" align="center" prop="name" label="姓名" width="80" fixed></el-table-column>
		<el-table-column v-if="colData[2].istrue" align="center" prop="age" label="age" width="60"></el-table-column>
		<el-table-column v-if="colData[3].istrue" align="center" prop="gender" label="性別" width="80"></el-table-column>
		<el-table-column v-if="colData[4].istrue" align="center" prop="department" label="部署名" width="100"></el-table-column>
	</el-table-column>
	......

jsデータが保存されるデータ部分

	// リストの動的非表示 colData: [
	   { title: "作品番号", istrue: true },
	   { title: "名前", istrue: true },
	   { title: "年齢", istrue: true },
	   { title: "性別", istrue: true },
	   { title: "部門名", istrue: true },	   
	 ]、
	 チェックボックスグループ: [],
	 チェックされた列: [],

jsメソッド実装部分

作成された() {      
	  // 列フィルタリング this.colData.forEach((item, index) => {
	    this.checkBoxGroup.push(item.title);
	    this.checkedColumns.push(item.title);
	  })
	  this.checkedColumns = this.checkedColumns
	  UnData = localStorage.getItem(this.colTable) とします。
	  UnData = JSON.parse(UnData)
	  もし(UnData!= null){
	    this.checkedColumns = this.checkedColumns.filter((item) => {
	      !UnData.includes(item) を返します
	    })
	  }
	},
 // 監視列の非表示ウォッチ: {
   チェックされた列(val,value) {
     let arr = this.checkBoxGroup.filter(i => !val.includes(i)); // チェックなし localStorage.setItem(this.colTable, JSON.stringify(arr))
     this.colData.filter(i => {
       (arr.indexOf(i.title) != -1) の場合 {
         i.istrue = false;
       } それ以外 {
         i.istrue = 真;
       }
     });
   }
 },

これで可能になり、ページを更新すると選択状態が記録されるようになります。 当初は全選択の選択ボックスを追加したかったのですが、結局実装されませんでした。 まずはこの方法で使ってみましょう。でも、もっと良い方法があるはずなので、最適化してから更新します〜

これで、vue+element テーブルで動的な列フィルタリングを実装するためのサンプルコードに関するこの記事は終了です。element テーブルでの動的な列フィルタリングに関する詳細については、123WORDPRESS.COM の以前の記事を検索するか、次の関連記事を引き続き参照してください。今後とも 123WORDPRESS.COM をよろしくお願いいたします。

以下もご興味があるかもしれません:
  • Vue+Element の動的フォーム、動的テーブル (バックエンドが設定を送信し、フロントエンドが動的に生成) の詳細な説明
  • 要素内のテーブルを動的にマージする手順
  • Vue+elementは動的なフォームを作成し、テーブルの行と列を動的に生成します
  • elementUI テーブルの動的マージのサンプル コード
  • VUE2.0+ElementUI2.0 テーブル el-table loop 動的列レンダリングの書き方を詳しく解説
  • 要素 UI テーブルの動的列に空白が表示されるバグ修正方法
  • 動的テーブルを実装するための要素サンプルコード

<<:  Vue再帰コンポーネントの簡単な使用例

>>:  Vue で SVG アイコンを導入する 2 つの方法

推薦する

Win10 は Tsinghua ソースを使用して pytorch-GPU バージョンをすばやくインストールします (推奨)

Cudaがインストールされているかどうかを確認してくださいアナコンダプロンプトに入力nvcc -V...

JS の 3 つの主要な問題、非同期性とシングルスレッドについて簡単に説明します。

目次シングルスレッド非同期シングルスレッドしかし、開発中にネットワーク リクエストやスケジュールされ...

MySQL のスケジュールされた完全なデータベースバックアップ

目次1. MySQLデータのバックアップ1.1、データをバックアップするためのmysqldumpコマ...

Docker環境を構築する簡単な方法

まず、Docker とは何かを理解しましょう。 Docker は、アプリケーションをデプロイするため...

MySQLとOracleの違いを簡単に説明してください

1. Oracle は大規模データベースですが、MySQL は小規模から中規模のデータベースです。O...

Chrome 4.0 は GreaseMonkey スクリプトをサポートします

GreaseMokey (中国語では Grease Monkey Script と呼んでいます) は...

MySQL の垂直テーブルを水平テーブルに変換する方法と最適化のチュートリアル

1. 縦型テーブルと横型テーブル垂直テーブル: テーブル内のフィールドとフィールド値はキーと値の形式...

Vueはシンプルなコメント機能を実装します

この記事では、Vueの簡単なコメント機能を実装するための具体的なコードを参考までに共有します。具体的...

Docker でコンテナのポート マッピングを動的に変更する方法

前書き: Docker のポート マッピングは、多くの場合、Docker Run コマンド中に -p...

Hyper-v仮想マシンを使用してCentos7をインストールする

目次導入準備するシステムイメージをダウンロードHyper-Vを有効にする新しい仮想ネットワークスイッ...

React 純粋関数コンポーネント setState がページ更新を更新しない問題の解決方法

目次問題の説明:原因分析:解決:補足: Reactでは、フックが使用されている場合、useState...

Linux NFSメカニズムの動作原理と例の分析

NFS とは何ですか?ネットワークファイルシステムネットワーク上でファイルを保存および整理するための...

MySQLのREDOログ(リドゥログ)とロールバックログ(アンドゥログ)の詳しい説明

序文:前回の記事では、MySQL システムでよく使用されるログをいくつか説明しました。実は、トランザ...

IDEA に基づいて Tomcat サーバーを展開するための詳細な手順

目次導入ステップ1ステップ2: アイデアで動的Webプロジェクトを作成するステップ3: Tomcat...