Skip to content

Commit b6c384d

Browse files
jkzingyyx990803
authored andcommitted
fix(core): static trees should be cached on options (#6826) (#6837)
* test(once): failing test for #6826 * fix(core): static trees should be cached on options (#6826)
1 parent 9caed00 commit b6c384d

File tree

2 files changed

+25
-3
lines changed

2 files changed

+25
-3
lines changed

src/core/instance/render-helpers/render-static.js

+3-3
Original file line numberDiff line numberDiff line change
@@ -11,8 +11,8 @@ export function renderStatic (
1111
): VNode | Array<VNode> {
1212
// static trees can be rendered once and cached on the contructor options
1313
// so every instance shares the same cached trees
14-
const renderFns = this.$options.staticRenderFns
15-
const cached = renderFns.cached || (renderFns.cached = [])
14+
const options = this.$options
15+
const cached = options.cached || (options.cached = [])
1616
let tree = cached[index]
1717
// if has already-rendered static tree and not inside v-for,
1818
// we can reuse the same tree by doing a shallow clone.
@@ -22,7 +22,7 @@ export function renderStatic (
2222
: cloneVNode(tree)
2323
}
2424
// otherwise, render a fresh tree.
25-
tree = cached[index] = renderFns[index].call(this._renderProxy, null, this)
25+
tree = cached[index] = options.staticRenderFns[index].call(this._renderProxy, null, this)
2626
markStatic(tree, `__static__${index}`, false)
2727
return tree
2828
}

test/unit/features/directives/once.spec.js

+22
Original file line numberDiff line numberDiff line change
@@ -335,6 +335,28 @@ describe('Directive v-once', () => {
335335
vm.ok = false // teardown component with v-once
336336
}).then(done) // should not throw
337337
})
338+
339+
// #6826
340+
it('should render different component instances properly', done => {
341+
const vm = new Vue({
342+
components: {
343+
foo: {
344+
props: ['name'],
345+
template: '<div v-once>{{ name }}</div>'
346+
}
347+
},
348+
template: `
349+
<div>
350+
<foo name="a" v-once></foo>
351+
<foo name="b" v-once></foo>
352+
</div>
353+
`
354+
}).$mount()
355+
waitForUpdate(() => {
356+
expect(vm.$el.children[0].innerHTML).toBe('a')
357+
expect(vm.$el.children[1].innerHTML).toBe('b')
358+
}).then(done)
359+
})
338360
})
339361

340362
function expectTextContent (vm, text) {

0 commit comments

Comments
 (0)