refactor(fragments): remove visible anchors for fragments
This commit is contained in:
@@ -25,10 +25,11 @@ describe('renderer: fragment', () => {
|
||||
const root = nodeOps.createElement('div')
|
||||
render(h(App), root)
|
||||
|
||||
expect(serializeInner(root)).toBe(`<!----><div>one</div>two<!---->`)
|
||||
expect(serializeInner(root)).toBe(`<div>one</div>two`)
|
||||
expect(root.children.length).toBe(4)
|
||||
expect(root.children[0]).toMatchObject({
|
||||
type: NodeTypes.COMMENT
|
||||
type: NodeTypes.TEXT,
|
||||
text: ''
|
||||
})
|
||||
expect(root.children[1]).toMatchObject({
|
||||
type: NodeTypes.ELEMENT,
|
||||
@@ -43,7 +44,8 @@ describe('renderer: fragment', () => {
|
||||
text: 'two'
|
||||
})
|
||||
expect(root.children[3]).toMatchObject({
|
||||
type: NodeTypes.COMMENT
|
||||
type: NodeTypes.TEXT,
|
||||
text: ''
|
||||
})
|
||||
})
|
||||
|
||||
@@ -51,7 +53,7 @@ describe('renderer: fragment', () => {
|
||||
const root = nodeOps.createElement('div')
|
||||
render(h('div', [h(Fragment, [h('div', 'one'), 'two'])]), root)
|
||||
const parent = root.children[0] as TestElement
|
||||
expect(serializeInner(parent)).toBe(`<!----><div>one</div>two<!---->`)
|
||||
expect(serializeInner(parent)).toBe(`<div>one</div>two`)
|
||||
})
|
||||
|
||||
it('patch fragment children (manual, keyed)', () => {
|
||||
@@ -60,18 +62,14 @@ describe('renderer: fragment', () => {
|
||||
h(Fragment, [h('div', { key: 1 }, 'one'), h('div', { key: 2 }, 'two')]),
|
||||
root
|
||||
)
|
||||
expect(serializeInner(root)).toBe(
|
||||
`<!----><div>one</div><div>two</div><!---->`
|
||||
)
|
||||
expect(serializeInner(root)).toBe(`<div>one</div><div>two</div>`)
|
||||
|
||||
resetOps()
|
||||
render(
|
||||
h(Fragment, [h('div', { key: 2 }, 'two'), h('div', { key: 1 }, 'one')]),
|
||||
root
|
||||
)
|
||||
expect(serializeInner(root)).toBe(
|
||||
`<!----><div>two</div><div>one</div><!---->`
|
||||
)
|
||||
expect(serializeInner(root)).toBe(`<div>two</div><div>one</div>`)
|
||||
const ops = dumpOps()
|
||||
// should be moving nodes instead of re-creating or patching them
|
||||
expect(ops).toMatchObject([
|
||||
@@ -84,15 +82,11 @@ describe('renderer: fragment', () => {
|
||||
it('patch fragment children (manual, unkeyed)', () => {
|
||||
const root = nodeOps.createElement('div')
|
||||
render(h(Fragment, [h('div', 'one'), h('div', 'two')]), root)
|
||||
expect(serializeInner(root)).toBe(
|
||||
`<!----><div>one</div><div>two</div><!---->`
|
||||
)
|
||||
expect(serializeInner(root)).toBe(`<div>one</div><div>two</div>`)
|
||||
|
||||
resetOps()
|
||||
render(h(Fragment, [h('div', 'two'), h('div', 'one')]), root)
|
||||
expect(serializeInner(root)).toBe(
|
||||
`<!----><div>two</div><div>one</div><!---->`
|
||||
)
|
||||
expect(serializeInner(root)).toBe(`<div>two</div><div>one</div>`)
|
||||
const ops = dumpOps()
|
||||
// should be patching nodes instead of moving or re-creating them
|
||||
expect(ops).toMatchObject([
|
||||
@@ -119,7 +113,7 @@ describe('renderer: fragment', () => {
|
||||
),
|
||||
root
|
||||
)
|
||||
expect(serializeInner(root)).toBe(`<!----><div>one</div>two<!---->`)
|
||||
expect(serializeInner(root)).toBe(`<div>one</div>two`)
|
||||
|
||||
render(
|
||||
createVNode(
|
||||
@@ -134,7 +128,7 @@ describe('renderer: fragment', () => {
|
||||
),
|
||||
root
|
||||
)
|
||||
expect(serializeInner(root)).toBe(`<!----><div>foo</div>barbaz<!---->`)
|
||||
expect(serializeInner(root)).toBe(`<div>foo</div>barbaz`)
|
||||
})
|
||||
|
||||
it('patch fragment children (compiler generated, keyed)', () => {
|
||||
@@ -149,9 +143,7 @@ describe('renderer: fragment', () => {
|
||||
),
|
||||
root
|
||||
)
|
||||
expect(serializeInner(root)).toBe(
|
||||
`<!----><div>one</div><div>two</div><!---->`
|
||||
)
|
||||
expect(serializeInner(root)).toBe(`<div>one</div><div>two</div>`)
|
||||
|
||||
resetOps()
|
||||
render(
|
||||
@@ -163,9 +155,7 @@ describe('renderer: fragment', () => {
|
||||
),
|
||||
root
|
||||
)
|
||||
expect(serializeInner(root)).toBe(
|
||||
`<!----><div>two</div><div>one</div><!---->`
|
||||
)
|
||||
expect(serializeInner(root)).toBe(`<div>two</div><div>one</div>`)
|
||||
const ops = dumpOps()
|
||||
// should be moving nodes instead of re-creating or patching them
|
||||
expect(ops).toMatchObject([
|
||||
@@ -188,7 +178,7 @@ describe('renderer: fragment', () => {
|
||||
root
|
||||
)
|
||||
expect(serializeInner(root)).toBe(
|
||||
`<div><div>outer</div><!----><div>one</div><div>two</div><!----></div>`
|
||||
`<div><div>outer</div><div>one</div><div>two</div></div>`
|
||||
)
|
||||
|
||||
resetOps()
|
||||
@@ -203,7 +193,7 @@ describe('renderer: fragment', () => {
|
||||
root
|
||||
)
|
||||
expect(serializeInner(root)).toBe(
|
||||
`<div><!----><div>two</div><div>one</div><!----><div>outer</div></div>`
|
||||
`<div><div>two</div><div>one</div><div>outer</div></div>`
|
||||
)
|
||||
const ops = dumpOps()
|
||||
// should be moving nodes instead of re-creating them
|
||||
@@ -213,10 +203,10 @@ describe('renderer: fragment', () => {
|
||||
// 2. move entire fragment, including anchors
|
||||
// not the most efficient move, but this case is super rare
|
||||
// and optimizing for this special case complicates the algo quite a bit
|
||||
{ type: NodeOpTypes.INSERT, targetNode: { type: 'comment' } },
|
||||
{ type: NodeOpTypes.INSERT, targetNode: { type: 'text', text: '' } },
|
||||
{ type: NodeOpTypes.INSERT, targetNode: { type: 'element' } },
|
||||
{ type: NodeOpTypes.INSERT, targetNode: { type: 'element' } },
|
||||
{ type: NodeOpTypes.INSERT, targetNode: { type: 'comment' } }
|
||||
{ type: NodeOpTypes.INSERT, targetNode: { type: 'text', text: '' } }
|
||||
])
|
||||
})
|
||||
|
||||
@@ -234,7 +224,7 @@ describe('renderer: fragment', () => {
|
||||
root
|
||||
)
|
||||
expect(serializeInner(root)).toBe(
|
||||
`<!----><div>outer</div><!----><div>one</div><div>two</div><!----><!---->`
|
||||
`<div>outer</div><div>one</div><div>two</div>`
|
||||
)
|
||||
|
||||
resetOps()
|
||||
@@ -249,16 +239,16 @@ describe('renderer: fragment', () => {
|
||||
root
|
||||
)
|
||||
expect(serializeInner(root)).toBe(
|
||||
`<!----><!----><div>two</div><div>one</div><!----><div>outer</div><!---->`
|
||||
`<div>two</div><div>one</div><div>outer</div>`
|
||||
)
|
||||
const ops = dumpOps()
|
||||
// should be moving nodes instead of re-creating them
|
||||
expect(ops).toMatchObject([
|
||||
{ type: NodeOpTypes.INSERT, targetNode: { type: 'element' } },
|
||||
{ type: NodeOpTypes.INSERT, targetNode: { type: 'comment' } },
|
||||
{ type: NodeOpTypes.INSERT, targetNode: { type: 'text', text: '' } },
|
||||
{ type: NodeOpTypes.INSERT, targetNode: { type: 'element' } },
|
||||
{ type: NodeOpTypes.INSERT, targetNode: { type: 'element' } },
|
||||
{ type: NodeOpTypes.INSERT, targetNode: { type: 'comment' } }
|
||||
{ type: NodeOpTypes.INSERT, targetNode: { type: 'text', text: '' } }
|
||||
])
|
||||
|
||||
// should properly remove nested fragments
|
||||
|
||||
Reference in New Issue
Block a user