feat(TreeBenchmark): use angular2 If directive
This commit is contained in:
parent
58ba700b14
commit
8a3d9050d9
|
@ -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;
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue