欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

el-table表格排序(多列排序和遠(yuǎn)程排序)

 更新時(shí)間:2023年05月30日 11:02:55   作者:小星星__  
本文主要介紹了el-table表格排序(多列排序和遠(yuǎn)程排序),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧

前言

我們?cè)谧霰砀竦臅r(shí)候經(jīng)常會(huì)遇到表頭有一個(gè)排序的icon 用來(lái)對(duì)數(shù)據(jù)進(jìn)行, el-table有自己的排序方法, 如下:

在列中設(shè)置sortable屬性即可實(shí)現(xiàn)以該列為基準(zhǔn)的排序,接受一個(gè)Boolean,默認(rèn)為false。

一、el-table支持調(diào)接口排序嗎?

el-table默認(rèn)的排序支持從接口獲取排序的數(shù)據(jù)

sortable: 對(duì)應(yīng)列是否可以排序,如果設(shè)置為 custom,則代表用戶希望遠(yuǎn)程排序,需要監(jiān)聽(tīng) Table 的 sort-change 事件

二、el-table支持多列排序嗎?

默認(rèn)的排序很簡(jiǎn)單, 加一個(gè)參數(shù)就可以了, 而且會(huì)自動(dòng)根據(jù)數(shù)據(jù)進(jìn)行排序, 但是我們會(huì)發(fā)現(xiàn), 默認(rèn)的排序只支持一列進(jìn)行排序, 當(dāng)我們排過(guò)一列之后在點(diǎn)擊另一列的排序圖標(biāo), 之前的排序就會(huì)消失??.

三、如何實(shí)現(xiàn)多列遠(yuǎn)程排序?

  • 自己寫(xiě)一個(gè)組件插入到表頭的位置實(shí)現(xiàn)排序
  • 根據(jù)el-table已有的屬性以及拋出的方法實(shí)現(xiàn)多列排序

如果手動(dòng)封裝一個(gè)組件肯定能實(shí)現(xiàn), 但是比較麻煩, 所以就研究了el-table相關(guān)了一些屬性和方法, 思路如下:

header-cell-class-name: 表頭單元格的 className 的回調(diào)方法,也可以使用字符串為所有表頭單元格設(shè)置一個(gè)固定的className

在點(diǎn)擊表頭的時(shí)候排序的列以及是升降序保存到一個(gè)數(shù)組對(duì)象ordersList里, 然后通過(guò)header-cell-class-name屬性設(shè)置選中的樣式.

四、核心代碼

data: {
	    return {
	       ordersList: [],
	    }
	}
	// 點(diǎn)擊表頭
	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)接口查詢,在傳參的時(shí)候把ordersList進(jìn)行處理成后端想要的格式(這里是把數(shù)據(jù)拋出, 外部調(diào)用組件的地方處理)
      this.sendInfo(this.ordersList, 'sort-change')
    },
    // 上面缺點(diǎn)是只能通過(guò)點(diǎn)擊表頭切換排序狀態(tài),點(diǎn)擊小三角排序不會(huì)觸發(fā),處理sort-change事件和點(diǎn)擊表頭一樣
    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è)置列的排序?yàn)槲覀冏远x的排序
    handleHeaderClass({ column }) {
      column.order = column.multiOrder
    }

這樣外部拿到的就是一個(gè)所有排序的數(shù)組, 包括prop以及當(dāng)前列的排序規(guī)則(ascending/descending/null), 將其處理成正確的入?yún)⒏袷郊纯?

到此這篇關(guān)于el-table表格排序(多列排序和遠(yuǎn)程排序)的文章就介紹到這了,更多相關(guān)el-table表格排序內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • Vue源碼解析之Template轉(zhuǎn)化為AST的實(shí)現(xiàn)方法

    Vue源碼解析之Template轉(zhuǎn)化為AST的實(shí)現(xiàn)方法

    這篇文章主要介紹了Vue源碼解析之Template轉(zhuǎn)化為AST的實(shí)現(xiàn)方法,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2018-12-12
  • Vue使得大屏自適應(yīng)的多種方法

    Vue使得大屏自適應(yīng)的多種方法

    這篇文章主要介紹了Vue使得大屏自適應(yīng)的多種方法,自適屏幕,始終保持16:9的比例,還一種是使用CSS scale屬性對(duì)大屏幕做自適應(yīng)處理,需要的朋友可以參考下
    2023-10-10
  • vue自動(dòng)化路由的實(shí)現(xiàn)代碼

    vue自動(dòng)化路由的實(shí)現(xiàn)代碼

    這篇文章主要介紹了vue自動(dòng)化路由的實(shí)現(xiàn)代碼,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2019-09-09
  • Vue3.4中v-model雙向數(shù)據(jù)綁定新玩法詳解

    Vue3.4中v-model雙向數(shù)據(jù)綁定新玩法詳解

    defineModel?是一個(gè)新的?<script?setup>?宏,旨在簡(jiǎn)化支持?v-model?的組件的實(shí)現(xiàn),?這個(gè)宏用來(lái)聲明一個(gè)雙向綁定?prop,下面我們就來(lái)看看他的具體使用吧
    2024-03-03
  • vue組件代碼分塊和懶加載講解

    vue組件代碼分塊和懶加載講解

    這篇文章主要介紹了vue組件代碼分塊和懶加載講解,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-04-04
  • vue中實(shí)現(xiàn)彈出層動(dòng)畫(huà)效果的示例代碼

    vue中實(shí)現(xiàn)彈出層動(dòng)畫(huà)效果的示例代碼

    這篇文章主要介紹了vue中怎樣實(shí)現(xiàn)彈出層動(dòng)畫(huà)效果,由上而下漸漸顯示,本文通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友參考下吧
    2020-09-09
  • 使用Vue完成一個(gè)簡(jiǎn)單的todolist的方法

    使用Vue完成一個(gè)簡(jiǎn)單的todolist的方法

    本篇文章主要介紹了使用Vue完成一個(gè)簡(jiǎn)單的todolist的方法,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2017-12-12
  • 圖文講解用vue-cli腳手架創(chuàng)建vue項(xiàng)目步驟

    圖文講解用vue-cli腳手架創(chuàng)建vue項(xiàng)目步驟

    本次小編給大家?guī)?lái)的是關(guān)于用vue-cli腳手架創(chuàng)建vue項(xiàng)目步驟講解內(nèi)容,有需要的朋友們可以學(xué)習(xí)下。
    2019-02-02
  • 如何在VUE中使用vue-awesome-swiper

    如何在VUE中使用vue-awesome-swiper

    這篇文章主要介紹了如何在VUE中使用vue-awesome-swiper,幫助大家更好的理解和使用vue框架,感興趣的朋友可以了解下
    2021-01-01
  • vue實(shí)現(xiàn)表單單獨(dú)移除一個(gè)字段驗(yàn)證

    vue實(shí)現(xiàn)表單單獨(dú)移除一個(gè)字段驗(yàn)證

    這篇文章主要為大家詳細(xì)介紹了vue實(shí)現(xiàn)表單單獨(dú)移除一個(gè)字段驗(yàn)證,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2022-03-03

最新評(píng)論