diff --git a/packages/runtime-core/__tests__/apiOptions.spec.ts b/packages/runtime-core/__tests__/apiOptions.spec.ts index 9c50664b..0dda6426 100644 --- a/packages/runtime-core/__tests__/apiOptions.spec.ts +++ b/packages/runtime-core/__tests__/apiOptions.spec.ts @@ -1265,14 +1265,22 @@ describe('api: options', () => { test('this.$options[lifecycle-name]', () => { const mixin = { - mounted() {} + mounted() {}, + beforeUnmount() {}, + unmounted() {} } createApp({ mixins: [mixin], mounted() {}, + beforeUnmount() {}, + unmounted() {}, created() { expect(this.$options.mounted).toBeInstanceOf(Array) expect(this.$options.mounted.length).toBe(2) + expect(this.$options.beforeUnmount).toBeInstanceOf(Array) + expect(this.$options.beforeUnmount.length).toBe(2) + expect(this.$options.unmounted).toBeInstanceOf(Array) + expect(this.$options.unmounted.length).toBe(2) }, render: () => null }).mount(nodeOps.createElement('div')) diff --git a/packages/runtime-core/src/componentOptions.ts b/packages/runtime-core/src/componentOptions.ts index db12bfbc..41e02c5d 100644 --- a/packages/runtime-core/src/componentOptions.ts +++ b/packages/runtime-core/src/componentOptions.ts @@ -1015,7 +1015,9 @@ export const internalOptionMergeStrats: Record = { beforeUpdate: mergeAsArray, updated: mergeAsArray, beforeDestroy: mergeAsArray, + beforeUnmount: mergeAsArray, destroyed: mergeAsArray, + unmounted: mergeAsArray, activated: mergeAsArray, deactivated: mergeAsArray, errorCaptured: mergeAsArray,