File tree 2 files changed +25
-3
lines changed
src/core/instance/render-helpers
test/unit/features/directives
2 files changed +25
-3
lines changed Original file line number Diff line number Diff line change @@ -11,8 +11,8 @@ export function renderStatic (
11
11
) : VNode | Array < VNode > {
12
12
// static trees can be rendered once and cached on the contructor options
13
13
// 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 = [ ] )
16
16
let tree = cached [ index ]
17
17
// if has already-rendered static tree and not inside v-for,
18
18
// we can reuse the same tree by doing a shallow clone.
@@ -22,7 +22,7 @@ export function renderStatic (
22
22
: cloneVNode ( tree )
23
23
}
24
24
// 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 )
26
26
markStatic ( tree , `__static__${ index } ` , false )
27
27
return tree
28
28
}
Original file line number Diff line number Diff line change @@ -335,6 +335,28 @@ describe('Directive v-once', () => {
335
335
vm . ok = false // teardown component with v-once
336
336
} ) . then ( done ) // should not throw
337
337
} )
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
+ } )
338
360
} )
339
361
340
362
function expectTextContent ( vm , text ) {
You can’t perform that action at this time.
0 commit comments