element el-table表格切換分頁保留分頁數據+限制多選數量

el-table表格并沒有相關的方法來禁用表頭里面的多選按鈕

在這里插入圖片描述

那么我們可以另辟蹊徑,來實現相同的多選+切換分頁(保留分頁數據)+ 限制多選數量的效果

<el-table:data="tableData"style="width: 100%">// 不使用el-talbe自帶的多選功能//<el-table-column type="selection" width="55"></el-table-column>//自己單獨建一個el-table-column 來設置選中狀態<el-table-column fixed width="60"><template slot-scope="scope"><el-checkbox v-model="scope.row.isCheck":disabled="selectable(scope.row)"@change="checkChange($event, scope.$index, scope.row)"></el-checkbox></template></el-table-column><el-table-columnlabel="日期"width="120"><template slot-scope="scope">{{ scope.row.date }}</template></el-table-column>
</el-table>
//在獲取表格數據以后 遍歷表格,為每行數據添加上 isCheck 屬性,并設置默認值false
this.tableData.forEach(item =>{item.isCheck = false;
})

實現多選功能 checkChange

 //事件有三個參數  // val el-checkbox change事件返回的值 代表 選中/不選中// index 當前tableData 所在的行// row 當前tableData 當前行的數據checkChange(val, index, row) {//通過val true/false ;來判斷是 選中當前行/取消選中當前行if (val) {//選中 往多選數組里面推送this.multipleSelection.push(row);} else {//取消選中(刪除) 拿到當前數據的唯一標識id const { id } = row;let delIndex = this.multipleSelection.findIndex((item) => item.id=== id);//刪除 取消選中的數據if (delIndex !== -1) {this.multipleSelection.splice(delIndex, 1);}}//重新設置 表格當前行的多選狀態this.$set(this.tableData, index, { ...row, isCheck: !!val });},

實現 限制多選數量的功能 selectable(scope.row)

//我們在最上面的實例中定義了一個 el-checkbox的禁用方法  :disabled="selectable(scope.row)"//限制最多只能選擇5個
// 方法返回 true/false 來實現el-checkbox的禁用/選中功能
selectable(row) {//限制多選最多只能選擇5個let limitNum = 5let ids = this.multipleSelection.map((item) => item.id);//判斷當前行的唯一標識符 id,是否存在于多選數組中if (ids.includes(row.id)) {// 已選擇的行,可取消禁用return false;} else if (ids.length >= limitNum  && !ids.includes(row.coilNo)) {// 超過最大選擇條數,且當前行未被選中時,禁用return true;} else {// 其他情況下可選 取消禁用return false;}
}

實現切換分頁保留分頁數據功能

//獲取表格數據
getTableData(){//模擬數據獲取this.tableData = res.data || []//判斷選中數組是否有值 有值(執行回顯選中數據功能)if (this.multipleSelection.length > 0) {this.echoMultiple();}
}//回顯多選值
echoMultiple() {//增加校驗 如果當前tableData沒有值 就不回顯選中數據if (this.multipleSelection.length === 0 || this.tableData.length === 0) {return;}let ids = this.multipleSelection.map((item) => item.id) || [];this.tableData.forEach((item, index) => {//遍歷 tableData數值 找出符合要求的idif (ids.includes(item.id)) {// 為符合回顯要求的數據 設置選中狀態this.$set(this.tableData, index, { ...item, isCheck: true });}});//避免視圖不刷新 強制刷新視圖this.$forceUpdate();}

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/diannao/38791.shtml
繁體地址,請注明出處:http://hk.pswp.cn/diannao/38791.shtml
英文地址,請注明出處:http://en.pswp.cn/diannao/38791.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

農村程序員陳隨易2024年中總結

今天是 2024年7月1日&#xff0c;時間如白駒過隙&#xff0c;今年已去其一半。 總結一下今年上半年的情況&#xff0c;給大家提供一些參考和建議。 希望大家關注一下公眾號 陳隨易&#xff0c;有些內容只在公眾號發表。 先看看我的年初計劃&#xff0c;這個在今年年初的時候&…

泛微E9開發 限制明細表列的值重復

限制明細表列的值重復 1、需求說明2、實現方法3、擴展知識點3.1 修改單個字段值&#xff08;不支持附件類型&#xff09;3.1.1 格式3.1.2 參數3.1.3 案例 3.2 獲取明細行所有行標示3.2.1 格式3.2.2 參數說明 1、需求說明 限制明細表的“類型”字段&#xff0c;在同一個流程表單…

【全網首發】雙字重疊語序驗證碼識別

【省流&#xff1a;打算直接測試效果的可以訪問這個網址】 http://decaptcha.ai?project_namenetease_zh_overlap 【實現方案】 如圖所示&#xff0c;我們能看到&#xff0c;比起以往的“單個字”語序點選&#xff0c;這個驗證碼的難點在于“重疊漢字“&#xff0c;我們知道…

【Python機器學習】模型評估與改進——簡單的網格搜索

為了提升模型的泛化性能&#xff0c;我們可以通過調參來實現。 在嘗試調參之前&#xff0c;重要的是理解參數的含義&#xff0c;找到一個模型的重要參數&#xff08;提供最佳泛化性能的參數&#xff09;的取值是一項棘手的任務&#xff0c;但對于幾乎所有模型和數據集來說都是…

API-Window對象

學習目標&#xff1a; 掌握Window對象 學習內容&#xff1a; BOM&#xff08;瀏覽器對象模型&#xff09;定時器-延時函數JS執行機制location對象navigation對象history對象 BOM&#xff08;瀏覽器對象模型&#xff09;&#xff1a; BOM是瀏覽器對象模型。 window對象是一個全…

Windows 11的市場份額越來越大了,推薦你升級!

7月1日&#xff0c;系統之家發布最新數據&#xff0c;顯示Windows 11操作系統的市場份額正在穩步上升。自2021年10月Windows 11發布以來&#xff0c;Windows 10一直占據著市場主導地位&#xff0c;當時其市場份額高達81.44%。然而&#xff0c;隨著時間的推移&#xff0c;Window…

鴻蒙學習1:ArkTS基礎入門

1 變量和常量 1.1 變量 常見的基礎數據類型&#xff1a; string 字符串、number 數字、boolean布爾 判斷。 變量&#xff1a;專門用來存儲數據的容器。 語法&#xff1a;let 變量名: 數據類型 值。例如&#xff1a;let name: 張三;let price:number 12.4; let isSuccess …

【triton-inference-server】 官方python_backend 文檔及例子

https://github.com/triton-inference-server/python_backend#building-from-source 一。 從源碼構建python_backend root@ubuntu-server:/home/ubuntu/hzh# sudo apt-get install rapidjson-dev libarchive-dev zlib1g-dev Reading package lists... Done Building dependency…

vue3中的自定義指令

全局自定義指令 假設我們要創建一個全局指令v-highlight&#xff0c;用于高亮顯示元素。這個指令將接受一個顏色參數&#xff0c;并有一個可選的修飾符bold來決定是否加粗文本。 首先&#xff0c;在創建Vue應用時定義這個指令&#xff1a;&#xff08;這里可以將指令抽離成單…

昂科燒錄器支持BPS晶豐明源半導體的多相Buck控制器BPD93004E

芯片燒錄行業領導者-昂科技術近日發布最新的燒錄軟件更新及新增支持的芯片型號列表&#xff0c;其中BPS晶豐明源半導體的多相Buck控制器BPD93004E已經被昂科的通用燒錄平臺AP8000所支持。 BPD93004E是一款多相Buck控制器&#xff0c;支持原生1~4相&#xff0c;數字方式控制&am…

科普文:一文搞懂jvm原理(二)類加載器

概敘 科普文&#xff1a;一文搞懂jvm(一)jvm概敘-CSDN博客 前面我們介紹了jvm&#xff0c;jvm主要包括兩個子系統和兩個組件&#xff1a; Class loader(類裝載器) 子系統&#xff0c;Execution engine(執行引擎) 子系統&#xff1b;Runtime data area (運行時數據區域)組件&am…

Cambrian-1: A Fully Open, Vision-Centric Exploration of Multimodal LLMs

摘要 https://arxiv.org/pdf/2406.16860v1 我們介紹了Cambrian-1&#xff0c;這是一系列以視覺為中心的多模態大型語言模型&#xff08;MLLMs&#xff09;。盡管更強大的語言模型可以增強多模態能力&#xff0c;但視覺組件的設計選擇往往沒有得到充分的探索&#xff0c;并且與…

學習筆記(linux高級編程)9

void pthread_cleanup_push(void (*routine)(void *)&#xff0c; void *arg); 功能&#xff1a;注冊一個線程清理函數 參數&#xff0c;routine&#xff0c;線程清理函數的入口 arg&#xff0c;清理函數的參數。 返回值&#xff0c;無 void pthread_cleanup_pop(int execute)…

Perl語言入門指南

一、緒論 1.1 Perl語言概述 1.2 Perl的特色 1.3 Perl面臨的問題 1.4 Perl語言的應用領域 二、Perl語言基礎 2.1 Perl語言的歷史發展 2.2 Perl語言的基本語法 2.3 Perl語言的數據類型 三、Perl語言控制結構 3.1 條件語句 3.2 循環結構 3.3 函數和子程序 四、Perl語…

OpenStack開源虛擬化平臺(一)

目錄 一、OpenStack背景介紹&#xff08;一&#xff09;OpenStack是什么&#xff08;二&#xff09;OpenStack的主要服務 二、計算服務Nova&#xff08;一&#xff09;Nova組件介紹&#xff08;二&#xff09;Libvirt簡介&#xff08;三&#xff09;Nova中的RabbitMQ解析 OpenS…

MySQL-數據操作類型的角度理解 S鎖 X鎖

文章目錄 1、S鎖和S鎖互相兼容2、S鎖和X鎖互斥3、X鎖和X鎖也互斥4、X鎖和S鎖也互斥5、select * from account for update;6、select * from account for update nowait;7、select * from account for update skip locked; 1、S鎖和S鎖互相兼容 2、S鎖和X鎖互斥 3、X鎖和X鎖也互…

20240702 每日AI必讀資訊

&#x1f50d;GPTPdf&#xff1a;使用類似GPT-4o的多模態LLM分析PDF文件 - 使用類似 GPT-4o 多模態模型解析 PDF 文件&#xff0c;轉換為 Markdown 格式。 - 代碼簡潔高效&#xff0c;僅293行。 - 解析結果幾乎完美包括排版、數學公式、表格、圖片、圖表等內容。 &#x1…

【記錄】IDEA2023的激活與安裝

前言&#xff1a; 記錄IDEA2023的激活與安裝 第一步&#xff1a;官網下載安裝包&#xff1a; 下載地址&#xff1a;https://www.jetbrains.com/idea/download/other.html 這個最好選擇2023版本&#xff0c;用著很nice。 安裝步驟就不詳解了&#xff0c;無腦下一步就可以了…

(四十七)Vue Router之路由守衛

文章目錄 概念全局路由守衛全局前置守衛全局解析守衛全局后置路由守衛 獨享路由守衛組件內的守衛beforeRouteEnterbeforeRouteUpdatebeforeRouteLeave 完整的導航解析流程 上一篇&#xff1a;&#xff08;四十六&#xff09;Vue Router組件所獨有的兩個鉤子activate、deactivat…

VLAN原理與配置

AUTHOR &#xff1a;閆小雨 DATE&#xff1a;2024-04-28 目錄 VLAN的三種端口類型 VLAN原理 什么是VLAN 為什么使用VLAN VLAN的基本原理 VLAN標簽 VLAN標簽各字段含義如下&#xff1a; VLAN的劃分方式 VLAN的劃分包括如下5種方法&#xff1a; VLAN的接口鏈路類型 創建V…