vxe-table 啟用 checkbox-config.reserve 實現分頁復選框選擇功能、獲取已選數據的用法

vxe-table 啟用 checkbox-config.reserve 實現分頁復選框選擇功能、獲取已選數據的用法

查看官網:https://vxetable.cn
gitbub:https://github.com/x-extends/vxe-table
gitee:https://gitee.com/x-extends/vxe-table

效果

在這里插入圖片描述

代碼

獲取已選擇數據分為2個方法,一個是獲取當前頁 getCheckboxRecords(),一個是獲取已保留 getCheckboxReserveRecords()

getCheckboxRecords(isFull) 如果傳 true,則返回完整列表,包含被篩選之后的數據。不傳則不會返回被篩選掉的數據
getCheckboxReserveRecords(isFull) 如果傳 true,則返回完整列表,包含被篩選之后的數據。不傳則不會返回被篩選掉的數據

<template><div><vxe-button status="success" @click="getSelectEvent">獲取已選</vxe-button><vxe-grid ref="gridRef" v-bind="gridOptions" v-on="gridEvents"></vxe-grid></div>
</template><script setup>
import { ref, reactive } from 'vue'
import { VxeUI } from 'vxe-table'const gridRef = ref()const allList = [{ id: 10001, name: 'Test1', nickname: 'T1', role: 'Develop', sex: 'Man', age: 28, address: 'Shenzhen' },{ id: 10002, name: 'Test2', nickname: 'T2', role: 'Test', sex: 'Women', age: 22, address: 'Guangzhou' },{ id: 10003, name: 'Test3', nickname: 'T3', role: 'PM', sex: 'Man', age: 32, address: 'Shanghai' },{ id: 10004, name: 'Test4', nickname: 'T4', role: 'Designer', sex: 'Women', age: 23, address: 'test abc' },{ id: 10005, name: 'Test5', nickname: 'T5', role: 'Develop', sex: 'Women', age: 30, address: 'Shanghai' },{ id: 10006, name: 'Test6', nickname: 'T6', role: 'Designer', sex: 'Women', age: 21, address: 'Shenzhen' },{ id: 10007, name: 'Test7', nickname: 'T7', role: 'Test', sex: 'Man', age: 29, address: 'Shenzhen' },{ id: 10008, name: 'Test8', nickname: 'T8', role: 'Develop', sex: 'Man', age: 35, address: 'test abc' },{ id: 10009, name: 'Test9', nickname: 'T9', role: 'Develop', sex: 'Man', age: 35, address: 'Shenzhen' },{ id: 100010, name: 'Test10', nickname: 'T10', role: 'Develop', sex: 'Man', age: 35, address: 'Guangzhou' },{ id: 100011, name: 'Test11', nickname: 'T11', role: 'Develop', sex: 'Man', age: 49, address: 'Guangzhou' },{ id: 100012, name: 'Test12', nickname: 'T12', role: 'Develop', sex: 'Women', age: 45, address: 'Shanghai' },{ id: 100013, name: 'Test13', nickname: 'T13', role: 'Test', sex: 'Women', age: 35, address: 'Guangzhou' },{ id: 100014, name: 'Test14', nickname: 'T14', role: 'Test', sex: 'Man', age: 29, address: 'Shanghai' },{ id: 100015, name: 'Test15', nickname: 'T15', role: 'Develop', sex: 'Man', age: 39, address: 'Guangzhou' },{ id: 100016, name: 'Test16', nickname: 'T16', role: 'Test', sex: 'Women', age: 35, address: 'Guangzhou' },{ id: 100017, name: 'Test17', nickname: 'T17', role: 'Test', sex: 'Man', age: 39, address: 'Shanghai' },{ id: 100018, name: 'Test18', nickname: 'T18', role: 'Develop', sex: 'Man', age: 44, address: 'Guangzhou' },{ id: 100019, name: 'Test19', nickname: 'T19', role: 'Develop', sex: 'Man', age: 39, address: 'Guangzhou' },{ id: 100020, name: 'Test20', nickname: 'T20', role: 'Test', sex: 'Women', age: 35, address: 'Guangzhou' },{ id: 100021, name: 'Test21', nickname: 'T21', role: 'Test', sex: 'Man', age: 39, address: 'Shanghai' },{ id: 100022, name: 'Test22', nickname: 'T22', role: 'Develop', sex: 'Man', age: 44, address: 'Guangzhou' }
]// 模擬前端分頁
const handlePageData = () => {gridOptions.loading = truesetTimeout(() => {const { pageSize, currentPage } = gridOptions.pagerConfiggridOptions.pagerConfig.total = allList.lengthgridOptions.data = allList.slice((currentPage - 1) * pageSize, currentPage * pageSize)gridOptions.loading = false}, 100)
}const gridOptions = reactive({showOverflow: true,border: true,loading: false,height: 500,rowConfig: {keyField: 'id'},checkboxConfig: {reserve: true,showReserveStatus: true},pagerConfig: {total: 0,currentPage: 1,pageSize: 10},columns: [{ type: 'checkbox', width: 60 },{ field: 'name', title: 'Name', minWidth: 160 },{ field: 'email', title: 'Email', minWidth: 160 },{ field: 'nickname', title: 'Nickname', minWidth: 160 },{ field: 'age', title: 'Age', width: 100 },{ field: 'role', title: 'Role', minWidth: 160 },{ field: 'amount', title: 'Amount', width: 140 },{ field: 'updateDate', title: 'Update Date', visible: false },{ field: 'createDate', title: 'Create Date', visible: false }],data: []
})const gridEvents = {pageChange ({ pageSize, currentPage }) {gridOptions.pagerConfig.currentPage = currentPagegridOptions.pagerConfig.pageSize = pageSizehandlePageData()}
}const getSelectEvent = () => {const $grid = gridRef.valueif ($grid) {const selectRecords = $grid.getCheckboxRecords()const selectReserveRecords = $grid.getCheckboxReserveRecords()VxeUI.modal.message({content: `總共勾選: ${selectRecords.length + selectReserveRecords.length} 條,當前頁勾選:${selectRecords.length} 條,已保留勾選:${selectReserveRecords.length}`,status: 'success'})}
}handlePageData()
</script>

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

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

相關文章

藍橋杯-門牌制作

題目描述 本題為填空題&#xff0c;只需要算出結果后&#xff0c;在代碼中使用輸出語句將所填結果輸出即可。 小藍要為一條街的住戶制作門牌號。 這條街一共有 20202020 位住戶&#xff0c;門牌號從 11 到 20202020 編號。 小藍制作門牌的方法是先制作 00 到 99 這幾個數字…

C#調用Lua方法1+C#調用Lua方法2,3

xLua中Lua調用C#代碼 原因&#xff1a;C#實現的系統&#xff0c;因為Lua可以調用&#xff0c;所以完全可以換成Lua實現&#xff0c;因為Lua可以即時更改&#xff0c;即時運行&#xff0c;所以游戲的代碼邏輯就可以隨時更改。 實現和C#相同效果的系統&#xff0c;如何實現&#…

macOS Chrome - 打開開發者工具,設置 Local storage

文章目錄 macOS Chrome - 打開開發者工具設置 Local storage macOS Chrome - 打開開發者工具 方式2&#xff1a;右鍵點擊網頁&#xff0c;選擇 檢查 設置 Local storage 選擇要設置的 url&#xff0c;顯示右側面板 雙擊面板&#xff0c;輸入要添加的內容 2025-04-08&#xff…

zustand 源碼解析

文章目錄 實現原理createcreateStore 創建實例CreateStoreImpl 實現發布訂閱createImpl 包裝返回給用戶調用的 hookuseSyncExternalStoreWithSelector 訂閱更新zustand 性能優化自定義數據更新createWithEqualityFncreateWithEqualityFnImpl 返回 hookuseSyncExternalStoreWith…

kotlin,Android,jetpack compose,日期時間設置

AI生成&#xff0c;調試出來學習&#xff0c;這些小組件會用了&#xff0c;就可以組合一個大點的程序了。 package com.example.mydatetimeimport android.app.AlertDialog import android.os.Bundle import androidx.activity.ComponentActivity import androidx.activity.co…

構建k8s下Helm私有倉庫與自定義Chart開發指南

#作者&#xff1a;程宏斌 文章目錄 自定義helm模板1、開發自己的chare包2、調試chart3、安裝chart 自定義helm模板 https://hub.helm.sh/ 1、開發自己的chare包 [rootmaster ~]# helm create mychare //創建一個名為mychare的chare包 [rootmaster ~]# tree -C mychare/ //以…

MOP數據庫中的EXPLAIN用法

EXPLAIN 是 SQL 中的一個非常有用的工具&#xff0c;主要用于分析查詢語句的執行計劃。執行計劃能展示數據庫在執行查詢時的具體操作步驟&#xff0c;像表的讀取順序、使用的索引情況、數據的訪問方式等&#xff0c;這有助于我們對查詢性能進行優化。 語法 不同的數據庫系統&…

項目范圍蔓延的十大誘因及應對策略

項目范圍蔓延的十大誘因及應對策略是什么&#xff1f;主要在于&#xff1a; 缺乏清晰目標、利益相關方過多、需求變更未及時管控、缺少優先級體系、溝通鏈條冗長、管理層干預頻繁、資源與預算不匹配、技術風險被低估、合同或協議不完善、缺乏階段性驗收與復盤。其中缺乏清晰目標…

做好一個測試開發工程師第二階段:java入門:idea新建一個project后默認生成的.idea/src/out文件文件夾代表什么意思?

時間&#xff1a;2025.4.8 一、前言 關于Java與idea工具安裝不再展開&#xff0c;網上很多教程&#xff0c;可以自己去看 二、project建立后默認各文件夾代表意思 1、首先new---->project后會得到文件如圖 其中&#xff1a; .idea文件代表&#xff1a;存儲這個項目的歷史…

算法進階指南 分形

問題描述 分形&#xff0c;具有以非整數維形式充填空間的形態特征。通常被定義為&#xff1a; “一個粗糙或零碎的幾何形狀&#xff0c;可以分成數個部分&#xff0c;且每一部分都&#xff08;至少近似地&#xff09;是整體縮小后的形狀”&#xff0c;即具有自相似的性質。 現…

18-產品經理-跟蹤進度

禪道是一個可以幫助產品經理跟蹤研發進度的系統。通過禪道&#xff0c;產品經理可以從多個角度了解產品的研發狀態。在儀表盤中&#xff0c;可以展示所有產品或單一產品的概況&#xff0c;包括需求、計劃和發布數量&#xff0c;研發需求狀態&#xff0c;Bug修復率和計劃發布數。…

LeetCode算法題(Go語言實現)_36

題目 給定一個二叉樹的根節點 root &#xff0c;和一個整數 targetSum &#xff0c;求該二叉樹里節點值之和等于 targetSum 的 路徑 的數目。 路徑 不需要從根節點開始&#xff0c;也不需要在葉子節點結束&#xff0c;但是路徑方向必須是向下的&#xff08;只能從父節點到子節點…

深度解析:文件或目錄損壞且無法讀取的應對之道

引言 在數字化辦公與數據存儲日益普及的今天&#xff0c;我們時常會遭遇各種數據問題&#xff0c;其中“文件或目錄損壞且無法讀取”這一狀況尤為令人頭疼。無論是個人用戶存儲在電腦硬盤、移動硬盤、U盤等設備中的重要文檔、照片、視頻&#xff0c;還是企業服務器上的關鍵業務…

數據庫如何確定或計算 LSN(日志序列號)

目錄 如何確定或計算 LSN&#xff08;日志序列號&#xff09;**一、獲取當前 LSN****二、確定日志解析的起始 LSN****三、LSN 與物理文件的映射****四、應用場景** 如何確定或計算 LSN&#xff08;日志序列號&#xff09; LSN&#xff08;Log Sequence Number&#xff09;是數…

[ctfshow web入門] web24

前置知識 isset&#xff1a;判斷這個變量是否聲明且不為NULL&#xff0c;否則返回False mt_srand&#xff1a;設置隨機數種子&#xff0c;如果不手動設置&#xff0c;那么系統會自動進行一次隨機種子的設置 mt_rand&#xff1a;生成一個隨機數&#xff0c;這個隨機數與種子有個…

習題與正則表達式

思路&#xff1a; 二分查找&#xff1a; left 1&#xff08;最小可能距離&#xff09;&#xff0c;right L&#xff08;最大可能距離&#xff09;。 每次取 mid (left right) / 2&#xff0c;判斷是否可以通過增設 ≤ K 個路標使得所有相鄰路標的距離 ≤ mid。 貪心驗證…

最小K個數

文章目錄 題意思路代碼 題意 題目鏈接 思路 代碼 class Solution { public:vector<int> smallestK(vector<int>& arr, int k) {priority_queue<int> Q;for (auto &index:arr){Q.push(index);if (Q.size() > k)Q.pop();}vector<int> ans…

<tauri><rust><GUI>基于rust和tauri,將tauri程序打包為window系統可安裝的安裝包(exe、msi)

前言 本文是基于rust和tauri,由于tauri是前、后端結合的GUI框架,既可以直接生成包含前端代碼的文件,也可以在已有的前端項目上集成tauri框架,將前端頁面化為桌面GUI。 發文平臺 CSDN 環境配置 系統:windows 10平臺:visual studio code語言:rust、javascript庫:taur…

SAP系統采購信息記錄失效

問題&#xff1a;采購信息記錄失效 現象&#xff1a;最初主數據導入完成之后&#xff0c;單元測試的時采購信息記錄是有效的&#xff0c;中間經過配置的變化&#xff0c;集成測試初期發現采購信息記錄全部失效。 原因&#xff1a; 單元測試時發現采購訂單里面的條件類型…

視頻分析設備平臺EasyCVR打造汽車門店經營場景安全:AI智慧安防技術全解析

一、方案背景 某電動車企業不停爆出維權新聞&#xff0c;支持和反對的聲音此起彼伏&#xff0c;事情不斷發酵、反轉&#xff0c;每天都有新消息&#xff0c;令人目不暇接。車展、車店作為維權事件的高發場所&#xff0c;事后復盤和責任認定時&#xff0c;安防監控和視頻監控平…