refactor(benchmarks): refactor to support AOT bootstrap in G3 (#12075)
This commit is contained in:
parent
4a57dcfd8d
commit
5fa5ffb82a
|
@ -20,7 +20,9 @@
|
|||
});
|
||||
|
||||
// BOOTSTRAP the app!
|
||||
System.import('index').then(function(m: any) { m.main(); }, console.error.bind(console));
|
||||
System.import('index').then(function(m: any) {
|
||||
m.main && m.main();
|
||||
}, console.error.bind(console));
|
||||
}
|
||||
|
||||
function writeScriptTag(scriptUrl: string, onload?: string) {
|
||||
|
|
|
@ -22,9 +22,13 @@
|
|||
</p>
|
||||
|
||||
<div>
|
||||
<largetable id="root"></largetable>
|
||||
<largetable id="root">Loading...</largetable>
|
||||
</div>
|
||||
|
||||
<script src="../../bootstrap_plain.js"></script>
|
||||
<script>
|
||||
var mainUrl = window.location.search.split(/[?&]main=([^&]+)/)[1]
|
||||
|| '../../bootstrap_plain.js';
|
||||
document.write('<script src="' + mainUrl + '">\u003c/script>');
|
||||
</script>
|
||||
</body>
|
||||
</html>
|
|
@ -2,17 +2,22 @@ import {bindAction, profile} from '../../util';
|
|||
import {buildTable, emptyTable} from '../util';
|
||||
import {TableComponent} from './table';
|
||||
|
||||
export function main() {
|
||||
var table: TableComponent;
|
||||
|
||||
function destroyDom() { table.data = emptyTable; }
|
||||
function destroyDom() {
|
||||
table.data = emptyTable;
|
||||
}
|
||||
|
||||
function createDom() { table.data = buildTable(); }
|
||||
function createDom() {
|
||||
table.data = buildTable();
|
||||
}
|
||||
|
||||
function noop() {}
|
||||
|
||||
function init() {
|
||||
table = new TableComponent(document.querySelector('largetable'));
|
||||
const rootEl = document.querySelector('largetable');
|
||||
rootEl.textContent = '';
|
||||
table = new TableComponent(rootEl);
|
||||
|
||||
bindAction('#destroyDom', destroyDom);
|
||||
bindAction('#createDom', createDom);
|
||||
|
@ -22,4 +27,3 @@ export function main() {
|
|||
}
|
||||
|
||||
init();
|
||||
}
|
||||
|
|
|
@ -22,9 +22,13 @@
|
|||
</p>
|
||||
|
||||
<div>
|
||||
<largetable id="root"></largetable>
|
||||
<largetable id="root">Loading...</largetable>
|
||||
</div>
|
||||
|
||||
<script src="../../bootstrap_ng2.js"></script>
|
||||
<script>
|
||||
var mainUrl = window.location.search.split(/[?&]main=([^&]+)/)[1]
|
||||
|| '../../bootstrap_ng2.js';
|
||||
document.write('<script src="' + mainUrl + '">\u003c/script>');
|
||||
</script>
|
||||
</body>
|
||||
</html>
|
||||
|
|
|
@ -1,40 +1,10 @@
|
|||
import {ApplicationRef, enableProdMode} from '@angular/core';
|
||||
import {enableProdMode} from '@angular/core';
|
||||
import {platformBrowserDynamic} from '@angular/platform-browser-dynamic';
|
||||
|
||||
import {bindAction, profile} from '../../util';
|
||||
import {buildTable, emptyTable} from '../util';
|
||||
|
||||
import {AppModule, TableComponent} from './table';
|
||||
import {init} from './init';
|
||||
import {AppModule} from './table';
|
||||
|
||||
export function main() {
|
||||
var table: TableComponent;
|
||||
var appRef: ApplicationRef;
|
||||
|
||||
function destroyDom() {
|
||||
table.data = emptyTable;
|
||||
appRef.tick();
|
||||
}
|
||||
|
||||
function createDom() {
|
||||
table.data = buildTable();
|
||||
appRef.tick();
|
||||
}
|
||||
|
||||
function noop() {}
|
||||
|
||||
function init() {
|
||||
enableProdMode();
|
||||
platformBrowserDynamic().bootstrapModule(AppModule).then((ref) => {
|
||||
var injector = ref.injector;
|
||||
appRef = injector.get(ApplicationRef);
|
||||
|
||||
table = appRef.components[0].instance;
|
||||
bindAction('#destroyDom', destroyDom);
|
||||
bindAction('#createDom', createDom);
|
||||
bindAction('#updateDomProfile', profile(createDom, noop, 'update'));
|
||||
bindAction('#createDomProfile', profile(createDom, destroyDom, 'create'));
|
||||
});
|
||||
}
|
||||
|
||||
init();
|
||||
platformBrowserDynamic().bootstrapModule(AppModule).then(init);
|
||||
}
|
||||
|
|
|
@ -0,0 +1,32 @@
|
|||
import {ApplicationRef, NgModuleRef} from '@angular/core';
|
||||
|
||||
import {bindAction, profile} from '../../util';
|
||||
import {buildTable, emptyTable} from '../util';
|
||||
|
||||
import {AppModule, TableComponent} from './table';
|
||||
|
||||
export function init(moduleRef: NgModuleRef<AppModule>) {
|
||||
let table: TableComponent;
|
||||
let appRef: ApplicationRef;
|
||||
|
||||
function destroyDom() {
|
||||
table.data = emptyTable;
|
||||
appRef.tick();
|
||||
}
|
||||
|
||||
function createDom() {
|
||||
table.data = buildTable();
|
||||
appRef.tick();
|
||||
}
|
||||
|
||||
function noop() {}
|
||||
|
||||
const injector = moduleRef.injector;
|
||||
appRef = injector.get(ApplicationRef);
|
||||
|
||||
table = appRef.components[0].instance;
|
||||
bindAction('#destroyDom', destroyDom);
|
||||
bindAction('#createDom', createDom);
|
||||
bindAction('#updateDomProfile', profile(createDom, noop, 'update'));
|
||||
bindAction('#createDomProfile', profile(createDom, destroyDom, 'create'));
|
||||
}
|
|
@ -22,9 +22,13 @@
|
|||
</p>
|
||||
|
||||
<div>
|
||||
<largetable id="root"></largetable>
|
||||
<largetable id="root">Loading...</largetable>
|
||||
</div>
|
||||
|
||||
<script src="../../bootstrap_ng2.js"></script>
|
||||
<script>
|
||||
var mainUrl = window.location.search.split(/[?&]main=([^&]+)/)[1]
|
||||
|| '../../bootstrap_ng2.js';
|
||||
document.write('<script src="' + mainUrl + '">\u003c/script>');
|
||||
</script>
|
||||
</body>
|
||||
</html>
|
||||
|
|
|
@ -1,40 +1,10 @@
|
|||
import {ApplicationRef, enableProdMode} from '@angular/core';
|
||||
import {enableProdMode} from '@angular/core';
|
||||
import {platformBrowserDynamic} from '@angular/platform-browser-dynamic';
|
||||
|
||||
import {bindAction, profile} from '../../util';
|
||||
import {buildTable, emptyTable} from '../util';
|
||||
|
||||
import {AppModule, TableComponent} from './table';
|
||||
import {init} from './init';
|
||||
import {AppModule} from './table';
|
||||
|
||||
export function main() {
|
||||
var table: TableComponent;
|
||||
var appRef: ApplicationRef;
|
||||
|
||||
function destroyDom() {
|
||||
table.data = emptyTable;
|
||||
appRef.tick();
|
||||
}
|
||||
|
||||
function createDom() {
|
||||
table.data = buildTable();
|
||||
appRef.tick();
|
||||
}
|
||||
|
||||
function noop() {}
|
||||
|
||||
function init() {
|
||||
enableProdMode();
|
||||
platformBrowserDynamic().bootstrapModule(AppModule).then((ref) => {
|
||||
var injector = ref.injector;
|
||||
appRef = injector.get(ApplicationRef);
|
||||
|
||||
table = appRef.components[0].instance;
|
||||
bindAction('#destroyDom', destroyDom);
|
||||
bindAction('#createDom', createDom);
|
||||
bindAction('#updateDomProfile', profile(createDom, noop, 'update'));
|
||||
bindAction('#createDomProfile', profile(createDom, destroyDom, 'create'));
|
||||
});
|
||||
}
|
||||
|
||||
init();
|
||||
platformBrowserDynamic().bootstrapModule(AppModule).then(init);
|
||||
}
|
||||
|
|
|
@ -0,0 +1,32 @@
|
|||
import {ApplicationRef, NgModuleRef} from '@angular/core';
|
||||
|
||||
import {bindAction, profile} from '../../util';
|
||||
import {buildTable, emptyTable} from '../util';
|
||||
|
||||
import {AppModule, TableComponent} from './table';
|
||||
|
||||
export function init(moduleRef: NgModuleRef<AppModule>) {
|
||||
let table: TableComponent;
|
||||
let appRef: ApplicationRef;
|
||||
|
||||
function destroyDom() {
|
||||
table.data = emptyTable;
|
||||
appRef.tick();
|
||||
}
|
||||
|
||||
function createDom() {
|
||||
table.data = buildTable();
|
||||
appRef.tick();
|
||||
}
|
||||
|
||||
function noop() {}
|
||||
|
||||
const injector = moduleRef.injector;
|
||||
appRef = injector.get(ApplicationRef);
|
||||
|
||||
table = appRef.components[0].instance;
|
||||
bindAction('#destroyDom', destroyDom);
|
||||
bindAction('#createDom', createDom);
|
||||
bindAction('#updateDomProfile', profile(createDom, noop, 'update'));
|
||||
bindAction('#createDomProfile', profile(createDom, destroyDom, 'create'));
|
||||
}
|
|
@ -19,9 +19,13 @@
|
|||
</p>
|
||||
|
||||
<div>
|
||||
<tree id="root"></tree>
|
||||
<tree id="root">Loading...</tree>
|
||||
</div>
|
||||
|
||||
<script src="../../bootstrap_plain.js"></script>
|
||||
<script>
|
||||
var mainUrl = window.location.search.split(/[?&]main=([^&]+)/)[1]
|
||||
|| '../../bootstrap_plain.js';
|
||||
document.write('<script src="' + mainUrl + '">\u003c/script>');
|
||||
</script>
|
||||
</body>
|
||||
</html>
|
|
@ -2,17 +2,22 @@ import {bindAction, profile} from '../../util';
|
|||
import {buildTree, emptyTree} from '../util';
|
||||
import {TreeComponent} from './tree';
|
||||
|
||||
export function main() {
|
||||
var tree: TreeComponent;
|
||||
|
||||
function destroyDom() { tree.data = emptyTree; }
|
||||
function destroyDom() {
|
||||
tree.data = emptyTree;
|
||||
}
|
||||
|
||||
function createDom() { tree.data = buildTree(); }
|
||||
function createDom() {
|
||||
tree.data = buildTree();
|
||||
}
|
||||
|
||||
function noop() {}
|
||||
|
||||
function init() {
|
||||
tree = new TreeComponent(document.querySelector('tree'));
|
||||
const rootEl = document.querySelector('tree');
|
||||
rootEl.textContent = '';
|
||||
tree = new TreeComponent(rootEl);
|
||||
|
||||
bindAction('#destroyDom', destroyDom);
|
||||
bindAction('#createDom', createDom);
|
||||
|
@ -22,4 +27,3 @@ export function main() {
|
|||
}
|
||||
|
||||
init();
|
||||
}
|
||||
|
|
|
@ -19,9 +19,13 @@
|
|||
</p>
|
||||
|
||||
<div>
|
||||
<tree id="root"></tree>
|
||||
<tree id="root">Loading...</tree>
|
||||
</div>
|
||||
|
||||
<script src="../../bootstrap_ng2.js"></script>
|
||||
<script>
|
||||
var mainUrl = window.location.search.split(/[?&]main=([^&]+)/)[1]
|
||||
|| '../../bootstrap_ng2.js';
|
||||
document.write('<script src="' + mainUrl + '">\u003c/script>');
|
||||
</script>
|
||||
</body>
|
||||
</html>
|
||||
|
|
|
@ -1,40 +1,10 @@
|
|||
import {ApplicationRef, enableProdMode} from '@angular/core';
|
||||
import {enableProdMode} from '@angular/core';
|
||||
import {platformBrowserDynamic} from '@angular/platform-browser-dynamic';
|
||||
|
||||
import {bindAction, profile} from '../../util';
|
||||
import {buildTree, emptyTree} from '../util';
|
||||
|
||||
import {AppModule, TreeComponent} from './tree';
|
||||
import {init} from './init';
|
||||
import {AppModule} from './tree';
|
||||
|
||||
export function main() {
|
||||
var tree: TreeComponent;
|
||||
var appRef: ApplicationRef;
|
||||
|
||||
function destroyDom() {
|
||||
tree.data = emptyTree;
|
||||
appRef.tick();
|
||||
}
|
||||
|
||||
function createDom() {
|
||||
tree.data = buildTree();
|
||||
appRef.tick();
|
||||
}
|
||||
|
||||
function noop() {}
|
||||
|
||||
function init() {
|
||||
enableProdMode();
|
||||
platformBrowserDynamic().bootstrapModule(AppModule).then((ref) => {
|
||||
var injector = ref.injector;
|
||||
appRef = injector.get(ApplicationRef);
|
||||
|
||||
tree = appRef.components[0].instance;
|
||||
bindAction('#destroyDom', destroyDom);
|
||||
bindAction('#createDom', createDom);
|
||||
bindAction('#updateDomProfile', profile(createDom, noop, 'update'));
|
||||
bindAction('#createDomProfile', profile(createDom, destroyDom, 'create'));
|
||||
});
|
||||
}
|
||||
|
||||
init();
|
||||
platformBrowserDynamic().bootstrapModule(AppModule).then(init);
|
||||
}
|
||||
|
|
|
@ -0,0 +1,32 @@
|
|||
import {ApplicationRef, NgModuleRef} from '@angular/core';
|
||||
|
||||
import {bindAction, profile} from '../../util';
|
||||
import {buildTree, emptyTree} from '../util';
|
||||
|
||||
import {AppModule, TreeComponent} from './tree';
|
||||
|
||||
export function init(moduleRef: NgModuleRef<AppModule>) {
|
||||
let tree: TreeComponent;
|
||||
let appRef: ApplicationRef;
|
||||
|
||||
function destroyDom() {
|
||||
tree.data = emptyTree;
|
||||
appRef.tick();
|
||||
}
|
||||
|
||||
function createDom() {
|
||||
tree.data = buildTree();
|
||||
appRef.tick();
|
||||
}
|
||||
|
||||
function noop() {}
|
||||
|
||||
const injector = moduleRef.injector;
|
||||
appRef = injector.get(ApplicationRef);
|
||||
|
||||
tree = appRef.components[0].instance;
|
||||
bindAction('#destroyDom', destroyDom);
|
||||
bindAction('#createDom', createDom);
|
||||
bindAction('#updateDomProfile', profile(createDom, noop, 'update'));
|
||||
bindAction('#createDomProfile', profile(createDom, destroyDom, 'create'));
|
||||
}
|
Loading…
Reference in New Issue