跳到主要内容

onElementRemoval

分类
导出大小
735 B
上次更改
10 个月前

当元素或包含它的任何元素被移除时触发。

演示

演示1: 重新创建新元素

移除次数: 0

演示2: 复用相同元素

目标元素
移除次数: 0

用法

vue
<script setup lang="ts">
import { 
onElementRemoval
} from '@vueuse/core'
import {
shallowRef
,
useTemplateRef
} from 'vue'
const
btnRef
=
useTemplateRef
<HTMLElement>('btn')
const
btnState
=
shallowRef
(true)
const
removedCount
=
shallowRef
(0)
function
btnOnClick
() {
btnState
.
value
= !
btnState
.
value
}
onElementRemoval
(
btnRef
, () => ++
removedCount
.
value
)
</script> <template> <
button
v-if="
btnState
"
@
click
="
btnOnClick
"
> recreate me </
button
>
<
button
v-else
ref
="
btnRef
"
@
click
="
btnOnClick
"
> remove me </
button
>
<
b
>removed times: {{
removedCount
}}</
b
>
</template>

类型声明

ts
export interface OnElementRemovalOptions
  extends ConfigurableWindow,
    ConfigurableDocumentOrShadowRoot,
    WatchOptionsBase {}
/**
 * Fires when the element or any element containing it is removed.
 *
 * @param target
 * @param callback
 * @param options
 */
export declare function 
onElementRemoval
(
target
:
MaybeElementRef
,
callback
: (
mutationRecords
: MutationRecord[]) => void,
options
?: OnElementRemovalOptions,
):
Fn

来源

源代码演示文档

贡献者

Anthony Fu
IlyaL
Anthony Fu
Ben Lau

更新日志

v12.3.0
08cf5 - feat: 新功能,重构 useActiveElement useElementHover (#4410)

根据 MIT 许可证发布。