feat(TreeBenchmark): use angular2 If directive

This commit is contained in:
Victor Berchet 2015-02-20 09:48:16 +01:00
parent 58ba700b14
commit 8a3d9050d9
1 changed files with 12 additions and 25 deletions

View File

@ -19,6 +19,8 @@ import {getIntParameter, bindAction} from 'angular2/src/test_lib/benchmark_util'
import {XHR} from 'angular2/src/core/compiler/xhr/xhr'; import {XHR} from 'angular2/src/core/compiler/xhr/xhr';
import {XHRImpl} from 'angular2/src/core/compiler/xhr/xhr_impl'; import {XHRImpl} from 'angular2/src/core/compiler/xhr/xhr_impl';
import {If} from 'angular2/directives';
function setupReflector() { function setupReflector() {
// TODO: Put the general calls to reflector.register... in a shared file // TODO: Put the general calls to reflector.register... in a shared file
// as they are needed in all benchmarks... // as they are needed in all benchmarks...
@ -43,18 +45,18 @@ function setupReflector() {
bind: {'data': 'data'} bind: {'data': 'data'}
}), }),
new Template({ new Template({
directives: [TreeComponent, NgIf], directives: [TreeComponent, If],
inline: `<span> {{data.value}} <span template='ng-if data.right != null'><tree [data]='data.right'></tree></span><span template='ng-if data.left != null'><tree [data]='data.left'></tree></span></span>` inline: `<span> {{data.value}} <span template='if data.right != null'><tree [data]='data.right'></tree></span><span template='if data.left != null'><tree [data]='data.left'></tree></span></span>`
})] })]
}); });
reflector.registerType(NgIf, { reflector.registerType(If, {
'factory': (vp) => new NgIf(vp), 'factory': (vp) => new If(vp),
'parameters': [[ViewContainer]], 'parameters': [[ViewContainer]],
'annotations' : [new Viewport({ 'annotations' : [new Viewport({
selector: '[ng-if]', selector: '[if]',
bind: { bind: {
'ngIf': 'ng-if' 'condition': 'if'
} }
})] })]
}); });
@ -133,7 +135,8 @@ function setupReflector() {
'left': (a) => a.left, 'left': (a) => a.left,
'right': (a) => a.right, 'right': (a) => a.right,
'initData': (a) => a.initData, 'initData': (a) => a.initData,
'data': (a) => a.data 'data': (a) => a.data,
'condition': (a) => a.condition,
}); });
reflector.registerSetters({ reflector.registerSetters({
@ -142,7 +145,7 @@ function setupReflector() {
'right': (a,v) => a.right = v, 'right': (a,v) => a.right = v,
'initData': (a,v) => a.initData = v, 'initData': (a,v) => a.initData = v,
'data': (a,v) => a.data = v, 'data': (a,v) => a.data = v,
'ngIf': (a,v) => a.ngIf = v 'condition': (a,v) => a.condition = v,
}); });
} }
@ -265,7 +268,7 @@ function buildTree(maxDepth, values, curDepth) {
var BASELINE_TREE_TEMPLATE = DOM.createTemplate( var BASELINE_TREE_TEMPLATE = DOM.createTemplate(
'<span>_<template class="ng-binding"></template><template class="ng-binding"></template></span>'); '<span>_<template class="ng-binding"></template><template class="ng-binding"></template></span>');
var BASELINE_IF_TEMPLATE = DOM.createTemplate( var BASELINE_IF_TEMPLATE = DOM.createTemplate(
'<span template="ng-if"><tree></tree></span>'); '<span template="if"><tree></tree></span>');
// http://jsperf.com/nextsibling-vs-childnodes // http://jsperf.com/nextsibling-vs-childnodes
class BaseLineTreeComponent { class BaseLineTreeComponent {
@ -346,22 +349,6 @@ class AppComponent {
} }
} }
// TODO: Move this into a reusable directive in the 'core' module!
class NgIf {
_viewContainer:ViewContainer;
constructor(viewContainer:ViewContainer) {
this._viewContainer = viewContainer;
}
set ngIf(value:boolean) {
if (this._viewContainer.length > 0) {
this._viewContainer.remove(0);
}
if (value) {
this._viewContainer.create();
}
}
}
class TreeComponent { class TreeComponent {
data:TreeNode; data:TreeNode;
} }