Ver código fonte

fix(createKeyedFragment): improve insertion handling and reset state

daiwei 6 meses atrás
pai
commit
b0b5b7b209
1 arquivos alterados com 19 adições e 1 exclusões
  1. 19 1
      packages/runtime-vapor/src/apiCreateFragment.ts

+ 19 - 1
packages/runtime-vapor/src/apiCreateFragment.ts

@@ -1,11 +1,29 @@
-import type { Block, BlockFn } from './block'
+import { type Block, type BlockFn, insert } from './block'
+import { advanceHydrationNode, isHydrating } from './dom/hydration'
 import { DynamicFragment } from './fragment'
+import {
+  insertionAnchor,
+  insertionParent,
+  resetInsertionState,
+} from './insertionState'
 import { renderEffect } from './renderEffect'
 
 export function createKeyedFragment(key: () => any, render: BlockFn): Block {
+  const _insertionParent = insertionParent
+  const _insertionAnchor = insertionAnchor
+  if (!isHydrating) resetInsertionState()
+
   const frag = __DEV__ ? new DynamicFragment('keyed') : new DynamicFragment()
   renderEffect(() => {
     frag.update(render, key())
   })
+
+  if (!isHydrating) {
+    if (_insertionParent) insert(frag, _insertionParent, _insertionAnchor)
+  } else {
+    if (_insertionAnchor !== undefined) {
+      advanceHydrationNode(_insertionParent!)
+    }
+  }
   return frag
 }