關(guān)于vxe-table復(fù)選框翻頁(yè)選中問題及解決
vxe-table復(fù)選框翻頁(yè)選中問題
根據(jù)vxe-table官方文檔,想要保留勾選中的數(shù)據(jù),我們的代碼中需要設(shè)置“row-id”和:checkbox-config中的“reserve”屬性。

簡(jiǎn)單寫下html部分:
<vxe-grid
row-id="id"
:checkbox-config="{ labelField: '', highlight: true, trigger: 'row', reserve: true , range: true}"
@checkbox-all="selectAllEvent"
@checkbox-change="selectChangeEvent"
>
<!--自定義表格內(nèi)容-->
</vxe-grid>
因?yàn)轫?xiàng)目都用到vxe-table,所有這里使用vue的混入應(yīng)用的項(xiàng)目的所有頁(yè)面表格中,在混入文件中寫復(fù)選框的事件:
//定義數(shù)據(jù),簡(jiǎn)單模擬
data() {
return {
/*table選中keys*/
selectedRowKeys: [],
/*table選中records*/
selectionRows : [],
}
}
//復(fù)選框事件(保留翻頁(yè)選中的數(shù)據(jù))
selectChangeEvent({ checked, records, reserves, row }) {
// console.log(checked ? '勾選事件' : '取消事件')
// console.log('當(dāng)前選中的數(shù)據(jù):' + records)
// console.log('翻頁(yè)時(shí)其他頁(yè)的數(shù)據(jù):' + reserves)
// console.log('當(dāng)前選中的數(shù)據(jù)行:' + row )
//勾選選中時(shí)
if (checked) {
//第一次選數(shù)據(jù),還未進(jìn)行翻頁(yè)時(shí)
if (reserves.length == 0){
this.selectedRowKeys = records.map(v => v.id);
this.selectionRows = records;
}else {
//id集合,翻頁(yè)存在已選中的數(shù)據(jù)時(shí),拼接新選中的數(shù)據(jù)
this.selectedRowKeys = [...reserves.map(v => v.id),...records.map(v => v.id)];
//數(shù)據(jù)集合,翻頁(yè)存在已選中的數(shù)據(jù)時(shí),拼接新選中的數(shù)據(jù)
this.selectionRows = [...reserves,...records];
}
}else {
//取消選中時(shí)
let idIndex = this.selectedRowKeys.indexOf(row.id);
if (idIndex > -1) {
//刪除取消選中刪除指定元素id
this.$delete(this.selectedRowKeys, idIndex);
}
let dataIndex = null;
for(let i = 0; i < this.selectionRows.length; i++) {
if (this.selectionRows[i].id == row.id) {
dataIndex = i;
break;
}
}
//刪除取消選中的元素整個(gè)對(duì)象
this.$delete(this.selectionRows, dataIndex);
}
},
//vxe復(fù)選框當(dāng)前頁(yè)全選中方法(保留翻頁(yè)選中的數(shù)據(jù)):
selectAllEvent({ checked, records, reserves}) {
// console.log(checked ? '勾選事件' : '取消事件')
// console.log('當(dāng)前選中的數(shù)據(jù):' + records)
// console.log('翻頁(yè)時(shí)其他頁(yè)的數(shù)據(jù):' + reserves)
//全選中時(shí)
if (checked) {
//第一次選數(shù)據(jù),還未進(jìn)行翻頁(yè)時(shí)
if (reserves.length == 0){
this.selectedRowKeys = records.map(v => v.id);
this.selectionRows = records;
}else {
//id集合,翻頁(yè)存在已選中的數(shù)據(jù)時(shí),拼接新選中的數(shù)據(jù)
this.selectedRowKeys = [...reserves.map(v => v.id),...records.map(v => v.id)];
//數(shù)據(jù)集合,翻頁(yè)存在已選中的數(shù)據(jù)時(shí),拼接新選中的數(shù)據(jù)
this.selectionRows = [...reserves,...records];
}
}else {
//取消全選時(shí),直接將翻頁(yè)數(shù)據(jù)賦值,當(dāng)前頁(yè)數(shù)據(jù)不用加上
this.selectionRows = reserves;
this.selectedRowKeys = reserves.map(v => v.id)
}
}
上面就實(shí)現(xiàn)了vxe-table表格復(fù)選框選中和全選中事件,在進(jìn)行翻頁(yè)選其他頁(yè)的數(shù)據(jù)時(shí),還能保留前面選中的數(shù)據(jù)的功能。
vxe-table使用技巧總結(jié)
最近項(xiàng)目中需要用到多層樹table+checkbox勾選功能,選了一些組件,最終決定使用vxe-table。
Vxe-table功能豐富、api也多。官方例子很多比較粗淺,我花了很多精力才弄通了一些功能點(diǎn)及細(xì)節(jié)。在此匯總給大伙鋪鋪路。官網(wǎng):vxe-table v4,安裝配置和一般組件庫(kù)差不多,就不細(xì)說了。由于項(xiàng)目用的是vue2,所以vxe-table用的是v3版本。
1、樹形結(jié)構(gòu)配置
官方配置的樹是一個(gè)數(shù)組,需要在tree-config對(duì)象里設(shè)置transform為true,這樣才會(huì)自動(dòng)把數(shù)組轉(zhuǎn)換為需要的樹結(jié)構(gòu)。

如果已經(jīng)有一個(gè)具有樹形結(jié)構(gòu)的表數(shù)據(jù),則應(yīng)該設(shè)置transform為false。如下圖所示:


2、獲取全局table對(duì)象
this.$refs[vxe-table標(biāo)簽上的ref屬性值]
官方文檔中的table方法api都可以通過該對(duì)象調(diào)用,如
this.$refs['Tree' + this.activeName][0].setCheckboxRow(row,row.checkFlag) this.$refs['Tree' + this.activeName][0].loadData(this.middleValue) this.$refs['Tree' + this.activeName][0].remove(firstLoop)
3、使用多選框注意事項(xiàng)
在checkbox-config的checkField可以綁定選中屬性字段,勾選狀態(tài)為true,未勾選和半選狀態(tài)為false。
組件會(huì)自動(dòng)渲染勾選和未勾選狀態(tài),但不會(huì)自動(dòng)渲染半選狀態(tài),除非設(shè)置checkRowKeys,但這種方式只會(huì)在初始化時(shí)被觸發(fā)一次,動(dòng)態(tài)刷新時(shí)沒有相應(yīng)api觸發(fā)。
期間還試了很多方式都無法完美解決該問題,最后是采用slot模板插槽搞定的,我將在第七點(diǎn)詳細(xì)介紹。
4、編輯行或單元格注意事項(xiàng)

設(shè)置edit-config的mode為cell時(shí)是開啟單元格編輯模式,為row時(shí)是開啟行編輯模式;設(shè)置edit-config的activeMethod來決定該單元格是否允許編輯(該方法的返回值為true或false),如下圖所示,它的意思是只要表格行有childes屬性且該屬性不為空就不能點(diǎn)擊;edit-closed只對(duì) edit-config 配置時(shí)有效,單元格編輯狀態(tài)下被關(guān)閉時(shí)會(huì)觸發(fā)該事件,可以通過該事件實(shí)現(xiàn)實(shí)時(shí)保存編輯功能。
想要編輯的列插槽主要有三個(gè)屬性配置:
1、field:列字段名,這里需要的是直接可以取到的字段;2、edit-render:可編輯渲染器配置項(xiàng),具體用法可參考官網(wǎng)vxe-table v3:只對(duì) edit-render 啟用時(shí)有效,自定義可編輯組件模板,可傳多個(gè)參數(shù),如傳row的話,template里的標(biāo)簽可以獲取行數(shù)據(jù)。需要注意的是:field值和模板里的v-model值應(yīng)該為同一個(gè),才能實(shí)現(xiàn)雙向綁定,建議提前把想要編輯的字段放到可以直接取到的層級(jí)和地方。
5、表尾數(shù)據(jù)合并問題

配置show-footer為true可以開啟表尾,再通過footer-method方法獲取表尾的數(shù)據(jù),該數(shù)據(jù)是一個(gè)二維數(shù)組。這里需要注意一個(gè)問題:表尾數(shù)據(jù)在觸發(fā)方法獲取后只能通過編輯單元格動(dòng)態(tài)改變,通過該方法改變二維數(shù)組后是不會(huì)更新變化后的值。
6、僅顯示已勾選功能講解
這個(gè)功能就是通過loadData方法加載去掉未勾選行列表數(shù)據(jù)和原始表數(shù)據(jù)之間切換。全局table對(duì)象下有兩個(gè)字段:data和tableData,前者是動(dòng)態(tài)改變了數(shù)據(jù)的整個(gè)初始化表數(shù)據(jù),可以用來還原僅顯示已勾選功能,后者是現(xiàn)在加載著的表數(shù)據(jù),經(jīng)過處理后可以用來激活僅顯示已勾選功能。這里需要注意的是:vxe-table加載列表數(shù)據(jù)后會(huì)默認(rèn)自動(dòng)生成自定義行數(shù)據(jù)唯一主鍵字段_X_ROW_KEY,我們可以在數(shù)據(jù)處理時(shí)用上該字段,如下圖所示:


7、解決初始數(shù)據(jù)半選中狀態(tài)失效問題

我采用插槽方式自定義了checkbox,它的不確定狀態(tài)(半選)字段indeterminate我綁定了判斷是否半選方法:只要節(jié)點(diǎn)是未選中狀態(tài)且有選中狀態(tài)的兒子節(jié)點(diǎn)就是true半選狀態(tài),否則為false未選中狀態(tài)。

由于將checkbox自定義了,vxe-table的checkbox-change失效,所以要重新在vxe-checkbox里面綁定change事件。最簡(jiǎn)單的方式就是直接通過setCheckboxRow方法把勾選行設(shè)置勾選狀態(tài),它的好處是會(huì)把勾選節(jié)點(diǎn)的所有子節(jié)點(diǎn)一并設(shè)置是否勾選狀態(tài)。

以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
使用keep-alive時(shí),數(shù)據(jù)無法刷新的問題及解決
這篇文章主要介紹了使用keep-alive時(shí),數(shù)據(jù)無法刷新的問題及解決方案,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-07-07
vue+elementUI用戶修改密碼的前端驗(yàn)證規(guī)則
用戶登錄后修改密碼,密碼需要一定的驗(yàn)證規(guī)則,這篇文章主要介紹了vue+elementUI用戶修改密碼的前端驗(yàn)證,需要的朋友可以參考下2024-03-03
vue3 template轉(zhuǎn)為render函數(shù)過程詳解
在 Vue 中,template 模板是我們編寫組件的主要方式之一,而 Vue 內(nèi)部會(huì)將這些模板轉(zhuǎn)換為 render 函數(shù),render 函數(shù)是用于創(chuàng)建虛擬 DOM 的函數(shù),通過它,Vue 能夠高效地追蹤 DOM 的變化并進(jìn)行更新,下面我會(huì)通俗易懂地詳細(xì)解釋 Vue 如何將 template 轉(zhuǎn)換為 render 函數(shù)2024-10-10
Vue3+Vite使用雙token實(shí)現(xiàn)無感刷新
本文主要介紹了Vue3+Vite使用雙token實(shí)現(xiàn)無感刷新,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2023-04-04
Element-plus封裝搜索組件的實(shí)現(xiàn)
在后臺(tái)管理系統(tǒng)中,經(jīng)常需要在多個(gè)頁(yè)面中使用搜索功能,本文就來介紹一下Element-plus封裝搜索組件的實(shí)現(xiàn),具有一定的參考價(jià)值,感興趣的可以了解一下2024-08-08
vue3使用element-plus中el-table組件報(bào)錯(cuò)關(guān)鍵字'emitsOptions'與&
這篇文章主要給大家介紹了關(guān)于vue3使用element-plus中el-table組件報(bào)錯(cuò)關(guān)鍵字'emitsOptions'與'insertBefore'的相關(guān)資料,文中將解決方法介紹的非常詳細(xì),需要的朋友可以參考下2022-10-10

