watchArray
监视数组的添加和移除。
使用方法
类似于 watch
,但提供了添加和移除的元素给回调函数。如果列表通过 push
、splice
等方法原地更新,请传递 { deep: true }
。
ts
import { watchArray } from '@vueuse/core'
const list = ref([1, 2, 3])
watchArray(list, (newList, oldList, added, removed) => {
console.log(newList) // [1, 2, 3, 4]
console.log(oldList) // [1, 2, 3]
console.log(added) // [4]
console.log(removed) // []
})
onMounted(() => {
list.value = [...list.value, 4]
})
类型声明
typescript
export declare type WatchArrayCallback<V = any, OV = any> = (
value: V,
oldValue: OV,
added: V,
removed: OV,
onCleanup: (cleanupFn: () => void) => void,
) => any
/**
* 监视数组的添加和移除。
*
* @see https://vueuse.org/watchArray
*/
export declare function watchArray<
T,
Immediate extends Readonly<boolean> = false,
>(
source: WatchSource<T[]> | T[],
cb: WatchArrayCallback<T[], Immediate extends true ? T[] | undefined : T[]>,
options?: WatchOptions<Immediate>,
): WatchHandle
Source
贡献者
Anthony Fu
丶远方
Anthony Fu
sun0day
Di Weng