Vue+要素テーブルで動的列フィルタリングを実現

  • 要件:データを一覧で表示する場合、表示する項目が多く、特に横長の表になり、表示がわかりにくく、要点がつかみにくいと感じる場合があります。 .
  • 想定される実装: ユーザーは、テーブルの列を非表示にするか表示するかを手動で選択し、ユーザーの選択の状態を記録し、次に列に入るときに選択状態を保持します。
  • 効果の図は次のとおりです:
    オリジナル:ここに画像の説明を挿入
    不要な既定のチェックをオフにします:
    ここに画像の説明を挿入
    実装コード:
    HTML 部分は、複数選択ボックス コンポーネントを使用して列オプションを表示し、コントロールを
    使用して表示および非表示にし、列オプションをに渡します。v-if="colData[i].istrue"チェックボックスをオンにしてから、check イベントをバインドします。
<el-popover placement="right" title="列筛选" trigger="click" width="420">                        
	<el-checkbox-group v-model="checkedColumns" size="mini">
		<el-checkbox v-for="item in checkBoxGroup" :key="item" :label="item" :value="item"></el-checkbox>
	</el-checkbox-group>
	<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" fixed></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="年龄" 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 },	     
	  ],
	  checkBoxGroup: [],
	  checkedColumns: [],

jsメソッド実装部分

created() {
    
                
	    // 列筛选
	    this.colData.forEach((item, index) => {
    
    
	        this.checkBoxGroup.push(item.title);
	        this.checkedColumns.push(item.title);
	    })
	    this.checkedColumns = this.checkedColumns
	    let UnData = localStorage.getItem(this.colTable)
	    UnData = JSON.parse(UnData)
	    if (UnData != null) {
    
    
	        this.checkedColumns = this.checkedColumns.filter((item) => {
    
    
	            return !UnData.includes(item)
	        })
	    }
	},
  // 监控列隐藏
  watch: {
    
    
      checkedColumns(val,value) {
    
    
          let arr = this.checkBoxGroup.filter(i => !val.includes(i)); // 未选中
          localStorage.setItem(this.colTable, JSON.stringify(arr))
          this.colData.filter(i => {
    
    
              if (arr.indexOf(i.title) != -1) {
    
    
                  i.istrue = false;
              } else {
    
    
                  i.istrue = true;
              }
          });
      }
  },

こうすれば実現できて、ページを更新するとチェック状況が記録される 本来は全選択の選択ボックスを追加したかったのですが、結局実現しませんでした. まずはこのように使ってみましょう. しかし、もっと良い方法があるはずです。最適化後に更新されます〜

おすすめ

転載: blog.csdn.net/m0_46538057/article/details/112480900