Skip to content

useSorted

Category
Export Size
309 B
Last Changed
6 months ago

reactive sort array

Demo

input:
output: [ "18", "18", "28", "33", "34", "54", "61", "68", "76", "77", "77", "86" ]
object property sort:
input:
[ { "name": "John", "age": 40 }, { "name": "Jane", "age": 20 }, { "name": "Joe", "age": 30 }, { "name": "Jenny", "age": 22 } ]
output:
[ { "name": "Jane", "age": 20 }, { "name": "Jenny", "age": 22 }, { "name": "Joe", "age": 30 }, { "name": "John", "age": 40 } ]

Usage

ts
import { 
useSorted
} from '@vueuse/core'
// general sort const
source
= [10, 3, 5, 7, 2, 1, 8, 6, 9, 4]
const
sorted
=
useSorted
(
source
)
console
.
log
(
sorted
.
value
) // [1, 2, 3, 4, 5, 6, 7, 8, 9, 10]
console
.
log
(
source
) // [10, 3, 5, 7, 2, 1, 8, 6, 9, 4]
// object sort const
objArr
= [{
name
: 'John',
age
: 40,
}, {
name
: 'Jane',
age
: 20,
}, {
name
: 'Joe',
age
: 30,
}, {
name
: 'Jenny',
age
: 22,
}] const
objSorted
=
useSorted
(
objArr
, (
a
,
b
) =>
a
.
age
-
b
.
age
)

dirty mode

dirty mode will change the source array.

ts
const 
source
=
ref
([10, 3, 5, 7, 2, 1, 8, 6, 9, 4])
const
sorted
= useSorted(
source
, (
a
,
b
) =>
a
-
b
, {
dirty
: true,
})
console
.
log
(
source
)// output: 1, 2, 3, 4, 5, 6, 7, 8, 9, 10

Type Declarations

ts
export type 
UseSortedCompareFn
<
T
= any> = (
a
:
T
,
b
:
T
) => number
export type
UseSortedFn
<
T
= any> = (
arr
:
T
[],
compareFn
:
UseSortedCompareFn
<
T
>,
) =>
T
[]
export interface
UseSortedOptions
<
T
= any> {
/** * sort algorithm */
sortFn
?:
UseSortedFn
<
T
>
/** * compare function */
compareFn
?:
UseSortedCompareFn
<
T
>
/** * change the value of the source array * @default false */
dirty
?: boolean
} /** * reactive sort array * * @see https://vueuse.org/useSorted */ export declare function
useSorted
<
T
= any>(
source
:
MaybeRefOrGetter
<
T
[]>,
compareFn
?:
UseSortedCompareFn
<
T
>,
):
Ref
<
T
[]>
export declare function
useSorted
<
T
= any>(
source
:
MaybeRefOrGetter
<
T
[]>,
options
?:
UseSortedOptions
<
T
>,
):
Ref
<
T
[]>
export declare function
useSorted
<
T
= any>(
source
:
MaybeRefOrGetter
<
T
[]>,
compareFn
?:
UseSortedCompareFn
<
T
>,
options
?:
Omit
<
UseSortedOptions
<
T
>, "compareFn">,
):
Ref
<
T
[]>

Source

SourceDemoDocs

Contributors

Anthony Fu
Anthony Fu
Robin
IlyaL
Kasper Seweryn
Jelf

Changelog

v12.8.0 on
7432f - feat(types): deprecate MaybeRef and MaybeRefOrGetter in favor of Vue's native (#4636)
v12.3.0 on
59f75 - feat(toValue): deprecate toValue from @vueuse/shared in favor of Vue's native
v12.0.0-beta.1 on
0a9ed - feat!: drop Vue 2 support, optimize bundles and clean up (#4349)
v10.3.0 on
33a12 - feat: accept getter function as source (#3249)

Released under the MIT License.

FREE WEEKEND
48 Hours of Unlimited Official Vue.js Certification Training
Reserve Your Spot
23-24 August