diff --git a/src/generators/dom/visitors/IfBlock.ts b/src/generators/dom/visitors/IfBlock.ts
index f0a54a452488..117f9792523a 100644
--- a/src/generators/dom/visitors/IfBlock.ts
+++ b/src/generators/dom/visitors/IfBlock.ts
@@ -173,8 +173,10 @@ function simple(
`
: branch.hasIntroMethod
? deindent`
- if ( !${name} ) ${name} = ${branch.block}( ${params}, ${block.component} );
- ${name}.create();
+ if ( !${name} ) {
+ ${name} = ${branch.block}( ${params}, ${block.component} );
+ ${name}.create();
+ }
${name}.intro( ${parentNode}, ${anchor} );
`
: deindent`
diff --git a/test/runtime/samples/transition-js-if-block-in-each-block-bidi/_config.js b/test/runtime/samples/transition-js-if-block-in-each-block-bidi/_config.js
new file mode 100644
index 000000000000..f7ce778056c5
--- /dev/null
+++ b/test/runtime/samples/transition-js-if-block-in-each-block-bidi/_config.js
@@ -0,0 +1,45 @@
+export default {
+ data: {
+ threshold: 5
+ },
+
+ html: `
+
1
+ 2
+ 3
+ 4
+ 5
+ `,
+
+ test ( assert, component, target, window, raf ) {
+ const divs = target.querySelectorAll('div');
+
+ assert.equal(divs[0].foo, 0);
+
+ raf.tick(100);
+ assert.equal(divs[0].foo, 1);
+
+ component.set({ threshold: 4 });
+ assert.equal( divs[4].foo, 1 );
+
+ raf.tick( 200 );
+ assert.htmlEqual(target.innerHTML, `
+ 1
+ 2
+ 3
+ 4
+ `);
+
+ component.set({ threshold: 3 });
+ assert.equal( divs[3].foo, 1 );
+
+ raf.tick( 300 );
+ assert.htmlEqual(target.innerHTML, `
+ 1
+ 2
+ 3
+ `);
+
+ component.destroy();
+ }
+};
\ No newline at end of file
diff --git a/test/runtime/samples/transition-js-if-block-in-each-block-bidi/main.html b/test/runtime/samples/transition-js-if-block-in-each-block-bidi/main.html
new file mode 100644
index 000000000000..754c4a5bfd46
--- /dev/null
+++ b/test/runtime/samples/transition-js-if-block-in-each-block-bidi/main.html
@@ -0,0 +1,20 @@
+{{#each [1, 2, 3, 4, 5, 6, 7, 8, 9, 10] as number}}
+ {{#if threshold >= number}}
+ {{number}}
+ {{/if}}
+{{/each}}
+
+
\ No newline at end of file