排序

GitHub在 GitHub 上编辑
预设信息
@univerjs/preset-sheets-sort
需要服务端支持

排序功能允许用户对电子表格中的数据进行排序,以便更好地组织和分析信息。它支持多种排序方式,包括升序、降序和自定义排序,帮助用户快速找到所需数据。

预设模式

安装

npm install @univerjs/preset-sheets-sort

使用

import { UniverSheetsCorePreset } from '@univerjs/preset-sheets-core'
import UniverPresetSheetsCoreZhCN from '@univerjs/preset-sheets-core/locales/zh-CN'
import { UniverSheetsSortPreset } from '@univerjs/preset-sheets-sort'
import UniverPresetSheetsSortZhCN from '@univerjs/preset-sheets-sort/locales/zh-CN'
import { createUniver, LocaleType, merge } from '@univerjs/presets'

import '@univerjs/preset-sheets-core/lib/index.css'
import '@univerjs/preset-sheets-sort/lib/index.css'

const { univerAPI } = createUniver({
  locale: LocaleType.ZH_CN,
  locales: {
    [LocaleType.ZH_CN]: merge(
      {},
      UniverPresetSheetsCoreZhCN,
      UniverPresetSheetsSortZhCN, 
    ),
  },
  presets: [
    UniverSheetsCorePreset(),
    UniverSheetsSortPreset(), 
  ],
})

插件模式

安装

npm install @univerjs/sheets-sort @univerjs/sheets-sort-ui

使用

import { LocaleType, merge, Univer } from '@univerjs/core'
import { UniverSheetsSortPlugin } from '@univerjs/sheets-sort'
import { UniverSheetsSortUIPlugin } from '@univerjs/sheets-sort-ui'
import SheetsSortUIZhCN from '@univerjs/sheets-sort-ui/locale/zh-CN'

import '@univerjs/sheets-sort-ui/lib/index.css'

import '@univerjs/sheets-sort/facade'

const univer = new Univer({
  locale: LocaleType.ZH_CN,
  locales: {
    [LocaleType.ZH_CN]: merge(
      {},
      SheetsSortUIZhCN, 
    ),
  },
})

univer.registerPlugin(UniverSheetsSortPlugin) 
univer.registerPlugin(UniverSheetsSortUIPlugin) 

Facade API

完整 Facade API 类型定义,请查看 FacadeAPI

工作表排序

FWorksheet.sort(colIndex, asc) 方法可以按指定的列对工作表进行排序。

const fWorkbook = univerAPI.getActiveWorkbook()
const fWorksheet = fWorkbook.getActiveSheet()

// 按照第一列升序排序工作表
fWorksheet.sort(0)

// 按照第一列降序排序工作表
fWorksheet.sort(0, false)

区域排序

FRange.sort(column) 方法可以按指定的列和顺序对给定范围内的单元格进行排序。

const fWorkbook = univerAPI.getActiveWorkbook()
const fWorksheet = fWorkbook.getActiveSheet()
const fRange = fWorksheet.getRange('D1:G10')

// 按照第一列升序排序区域
fRange.sort(0)

// 按照第一列降序排序区域
fRange.sort({ column: 0, ascending: false })

// 按照第一列降序,第二列升序排序区域
fRange.sort([{ column: 0, ascending: false }, 1])

事件监听

完整事件类型定义,请查看 Events

SheetRangeSorted 事件在单元格范围排序完成后触发。

const disposable = univerAPI.addEvent(univerAPI.Event.SheetRangeSorted, (params) => {
  const { workbook, worksheet, range, sortColumn } = params
})

// 移除事件监听器,使用 `disposable.dispose()`

SheetBeforeRangeSort 事件在单元格范围排序前触发。

const disposable = univerAPI.addEvent(univerAPI.Event.SheetBeforeRangeSort, (params) => {
  const { workbook, worksheet, range, sortColumn } = params

  // 取消排序操作
  params.cancel = true
})

// 移除事件监听器,使用 `disposable.dispose()`