跳到主要內容

useArrayDifference

類別
匯出大小
256 B
最後變更
5 天前

響應式取得兩個陣列的差集。

預設情況下,它會返回第一個陣列與第二個陣列的差集,因此呼叫 A \ B,B 在 A 中的相對補集

您可以傳遞 symmetric 選項來取得兩個陣列 A △ B對稱差

用法

與響應式陣列一起使用

js
import { useArrayDifference } from '@vueuse/core'

const list1 = ref([0, 1, 2, 3, 4, 5])
const list2 = ref([4, 5, 6])
const result = useArrayDifference(list1, list2)
// result.value: [0, 1, 2, 3]
list2.value = [0, 1, 2]
// result.value: [3, 4, 5]

與響應式陣列一起使用並使用函式比較

js
import { useArrayDifference } from '@vueuse/core'

const list1 = ref([{ id: 1 }, { id: 2 }, { id: 3 }, { id: 4 }, { id: 5 }])
const list2 = ref([{ id: 4 }, { id: 5 }, { id: 6 }])

const result = useArrayDifference(list1, list2, (value, othVal) => value.id === othVal.id)
// result.value: [{ id: 1 }, { id: 2 }, { id: 3 }]

對稱差

此 composable 也支援對稱差,透過傳遞 symmetric 選項。

js
import { useArrayDifference } from '@vueuse/core'

const list1 = ref([{ id: 1 }, { id: 2 }, { id: 3 }, { id: 4 }, { id: 5 }])
const list2 = ref([{ id: 4 }, { id: 5 }, { id: 6 }])

const result = useArrayDifference(
  list1,
  list2,
  (value, othVal) => value.id === othVal.id,
  { symmetric: true }
)
// result.value: [{ id: 1 }, { id: 2 }, { id: 3 }, { id: 6 }]

類型宣告

typescript
export interface UseArrayDifferenceOptions {
  /**
   * Returns asymmetric difference
   *
   * @see https://en.wikipedia.org/wiki/Symmetric_difference
   * @default false
   */
  symmetric?: boolean
}
export declare function useArrayDifference<T>(
  list: MaybeRefOrGetter<T[]>,
  values: MaybeRefOrGetter<T[]>,
  key?: keyof T,
  options?: UseArrayDifferenceOptions,
): ComputedRef<T[]>
export declare function useArrayDifference<T>(
  list: MaybeRefOrGetter<T[]>,
  values: MaybeRefOrGetter<T[]>,
  compareFn?: (value: T, othVal: T) => boolean,
  options?: UseArrayDifferenceOptions,
): ComputedRef<T[]>

原始碼

原始碼文件

貢獻者

Anthony Fu
Anthony Fu
IlyaL
wangliangxin
chirokas
simpleoo0o
Lee Dogyeong
丶远方

更新日誌

v12.8.0 於 2025/3/5
7432f - feat(types): 棄用 MaybeRefMaybeRefOrGetter,改用 Vue 原生 (#4636)
v12.3.0 於 2025/1/2
59f75 - feat(toValue): 棄用 toValue from @vueuse/shared,改用 Vue 原生
v12.2.0-beta.1 於 2024/12/23
46fdc - feat: 新增 symmetric 選項 (#4146)
v12.0.0-beta.1 於 2024/11/21
0a9ed - feat!: 移除 Vue 2 支援,最佳化 bundle 並清理 (#4349)
v10.0.0-beta.5 於 2023/4/13
cb644 - refactor!: 移除 isFunctionisString 工具
v10.0.0-beta.4 於 2023/4/13
4d757 - feat(types)!: 將 MaybeComputedRef 重新命名為 MaybeRefOrGetter
0a72b - feat(toValue): 將 resolveUnref 重新命名為 toValue
v10.0.0-beta.1 於 2023/3/23
41858 - fix: 修正 falsey 值的錯誤 (#2869)
v10.0.0-beta.0 於 2023/3/14
a2a33 - feat: 新函式 (#2710)

以 MIT 授權條款發布。