fix(hydration): handle camel-case tag name when performing match assertion (#3247)

fix #3243
This commit is contained in:
HcySunYang 2021-03-26 23:59:50 +08:00 committed by GitHub
parent 420c8f4580
commit 9036f88d83
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
2 changed files with 11 additions and 1 deletions

View File

@ -626,6 +626,15 @@ describe('SSR hydration', () => {
expect(spy).toHaveBeenCalled()
})
test('elements with camel-case in svg ', () => {
const { vnode, container } = mountWithHydration(
'<animateTransform></animateTransform>',
() => h('animateTransform')
)
expect(vnode.el).toBe(container.firstChild)
expect(`Hydration node mismatch`).not.toHaveBeenWarned()
})
test('SVG as a mount container', () => {
const svgContainer = document.createElement('svg')
svgContainer.innerHTML = '<g></g>'

View File

@ -158,7 +158,8 @@ export function createHydrationFunctions(
if (shapeFlag & ShapeFlags.ELEMENT) {
if (
domType !== DOMNodeTypes.ELEMENT ||
vnode.type !== (node as Element).tagName.toLowerCase()
(vnode.type as string).toLowerCase() !==
(node as Element).tagName.toLowerCase()
) {
nextNode = onMismatch()
} else {