el-table表格排序(多列排序和遠程排序)
前言
我們在做表格的時候經(jīng)常會遇到表頭有一個排序的icon 用來對數(shù)據(jù)進行, el-table有自己的排序方法, 如下:
在列中設(shè)置sortable屬性即可實現(xiàn)以該列為基準的排序,接受一個Boolean,默認為false。
一、el-table支持調(diào)接口排序嗎?
el-table默認的排序支持從接口獲取排序的數(shù)據(jù)
sortable
: 對應(yīng)列是否可以排序,如果設(shè)置為custom
,則代表用戶希望遠程排序,需要監(jiān)聽 Table 的sort-change
事件
二、el-table支持多列排序嗎?
默認的排序很簡單, 加一個參數(shù)就可以了, 而且會自動根據(jù)數(shù)據(jù)進行排序, 但是我們會發(fā)現(xiàn), 默認的排序只支持一列進行排序, 當我們排過一列之后在點擊另一列的排序圖標, 之前的排序就會消失??.
三、如何實現(xiàn)多列遠程排序?
- 自己寫一個組件插入到表頭的位置實現(xiàn)排序
- 根據(jù)el-table已有的屬性以及拋出的方法實現(xiàn)多列排序
如果手動封裝一個組件肯定能實現(xiàn), 但是比較麻煩, 所以就研究了el-table相關(guān)了一些屬性和方法, 思路如下:
header-cell-class-name: 表頭單元格的 className 的回調(diào)方法,也可以使用字符串為所有表頭單元格設(shè)置一個固定的className
在點擊表頭的時候排序的列以及是升降序保存到一個數(shù)組對象ordersList
里, 然后通過header-cell-class-name
屬性設(shè)置選中的樣式.
四、核心代碼
data: { return { ordersList: [], } } // 點擊表頭 handleHeaderCLick(column){ if (column.sortable !== 'custom') { return } if (!column.multiOrder) { column.multiOrder = 'descending' } else if (column.multiOrder === 'descending') { column.multiOrder = 'ascending' } else { column.multiOrder = '' } this.handleOrderChange(column.property, column.multiOrder) }, handleOrderChange (orderColumn, orderState) { let result = this.ordersList.find(e => e.orderColumn === orderColumn) if (result) { result.orderState = orderState } else { this.ordersList.push({ orderColumn: orderColumn, orderState: orderState, }) } // 調(diào)接口查詢,在傳參的時候把ordersList進行處理成后端想要的格式(這里是把數(shù)據(jù)拋出, 外部調(diào)用組件的地方處理) this.sendInfo(this.ordersList, 'sort-change') }, // 上面缺點是只能通過點擊表頭切換排序狀態(tài),點擊小三角排序不會觸發(fā),處理sort-change事件和點擊表頭一樣 sortChange({column}) { // 有些列不需要排序,提前返回 if (column.sortable !== 'custom') { return } if (!column.multiOrder) { column.multiOrder = 'descending' } else if (column.multiOrder === 'descending') { column.multiOrder = 'ascending' } else { column.multiOrder = '' } this.handleOrderChange(column.property, column.multiOrder) }, // 設(shè)置列的排序為我們自定義的排序 handleHeaderClass({ column }) { column.order = column.multiOrder }
這樣外部拿到的就是一個所有排序的數(shù)組, 包括prop
以及當前列的排序規(guī)則(ascending
/descending
/null
), 將其處理成正確的入?yún)⒏袷郊纯?
到此這篇關(guān)于el-table表格排序(多列排序和遠程排序)的文章就介紹到這了,更多相關(guān)el-table表格排序內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Vue源碼解析之Template轉(zhuǎn)化為AST的實現(xiàn)方法
這篇文章主要介紹了Vue源碼解析之Template轉(zhuǎn)化為AST的實現(xiàn)方法,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2018-12-12Vue3.4中v-model雙向數(shù)據(jù)綁定新玩法詳解
defineModel?是一個新的?<script?setup>?宏,旨在簡化支持?v-model?的組件的實現(xiàn),?這個宏用來聲明一個雙向綁定?prop,下面我們就來看看他的具體使用吧2024-03-03圖文講解用vue-cli腳手架創(chuàng)建vue項目步驟
本次小編給大家?guī)淼氖顷P(guān)于用vue-cli腳手架創(chuàng)建vue項目步驟講解內(nèi)容,有需要的朋友們可以學(xué)習(xí)下。2019-02-02