本文整理汇总了TypeScript中angular2/src/render/dom/direct_dom_renderer.DirectDomRenderer.compile方法的典型用法代码示例。如果您正苦于以下问题:TypeScript DirectDomRenderer.compile方法的具体用法?TypeScript DirectDomRenderer.compile怎么用?TypeScript DirectDomRenderer.compile使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在类angular2/src/render/dom/direct_dom_renderer.DirectDomRenderer
的用法示例。
在下文中一共展示了DirectDomRenderer.compile方法的1个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的TypeScript代码示例。
示例1: _compileRecurse
_compileRecurse(template) {
var result = MapWrapper.get(this._compileCache, template.componentId);
if (isPresent(result)) {
return result;
}
result = this.renderer.compile(template).then((pv) => {
var childComponentPromises = ListWrapper.map(this._findNestedComponentIds(template, pv), (componentId) => {
var childTemplate = MapWrapper.get(this._templates, componentId);
if (isBlank(childTemplate)) {
throw new BaseException(`Could not find template for ${componentId}!`);
}
return this._compileRecurse(childTemplate);
});
return PromiseWrapper.all(childComponentPromises).then((protoViewRefsWithChildren) => {
var protoViewRefs = ListWrapper.map(protoViewRefsWithChildren, (arr) => arr[0]);
return this._flattenList([this.renderer.mergeChildComponentProtoViews(pv.render, protoViewRefs), protoViewRefsWithChildren]);
});
});
MapWrapper.set(this._compileCache, template.componentId, result);
return result;
}