only cache values if necessary

pull/769/head
Rich Harris 8 years ago
parent 427a0b5925
commit 136a2fd31c

@ -212,7 +212,7 @@ export default function visitComponent(
${updates.join('\n')}
if ( Object.keys( ${name}_changes ).length ) ${name}._set( ${name}_changes );
${name}._set( ${name}_changes );
`);
}

@ -10,17 +10,21 @@ export default function visitMustacheTag(
state: State,
node: Node
) {
const { dependencies, snippet } = block.contextualise(node.expression);
const shouldCache = node.expression.type !== 'Identifier' || block.contexts.has(node.expression.name);
const name = node._state.name;
const value = block.getUniqueName(`${name}_value`);
const value = shouldCache && block.getUniqueName(`${name}_value`);
const init = shouldCache ? `${value} = ${snippet}` : snippet;
const { dependencies, snippet } = block.contextualise(node.expression);
if (shouldCache) block.addVariable(value);
block.addVariable(value);
block.addElement(
name,
`@createText( ${value} = ${snippet} )`,
`@createText( ${init} )`,
generator.hydratable
? `@claimText( ${state.parentNodes}, ${value} = ${snippet} )`
? `@claimText( ${state.parentNodes}, ${init} )`
: '',
state.parentNode,
true
@ -32,10 +36,13 @@ export default function visitMustacheTag(
dependencies.map(dependency => `'${dependency}' in changed`).join(' || ')
);
block.builders.update.addBlock(deindent`
if ( ( ${changedCheck} ) && ${value} !== ( ${value} = ${snippet} ) ) {
${name}.data = ${value};
}
`);
const condition = shouldCache ?
`( ${changedCheck} ) && ${value} !== ( ${value} = ${snippet} )` :
changedCheck;
block.builders.update.addConditionalLine(
condition,
`${name}.data = ${shouldCache ? value : snippet};`
);
}
}

Loading…
Cancel
Save