本文整理匯總了TypeScript中aurelia-templating.ViewSlot.add方法的典型用法代碼示例。如果您正苦於以下問題:TypeScript ViewSlot.add方法的具體用法?TypeScript ViewSlot.add怎麽用?TypeScript ViewSlot.add使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在類aurelia-templating.ViewSlot
的用法示例。
在下文中一共展示了ViewSlot.add方法的5個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的TypeScript代碼示例。
示例1: createController
// creates a controller given a html template string and a viewmodel instance.
function createController(template, viewModel, viewsRequireLifecycle?: boolean) {
let childContainer = container.createChild();
let viewFactory = viewCompiler.compile(template);
if (viewsRequireLifecycle !== undefined) {
for (let id in viewFactory.instructions) {
let targetInstruction = viewFactory.instructions[id];
for (let behaviorInstruction of targetInstruction.behaviorInstructions) {
if (behaviorInstruction.attrName === 'repeat') {
behaviorInstruction.viewFactory._viewsRequireLifecycle = viewsRequireLifecycle;
}
}
}
}
let metadata = new HtmlBehaviorResource();
function App() {
//
}
metadata.initialize(childContainer, App);
metadata.elementName = metadata.htmlName = 'app';
let controller = metadata.create(childContainer, BehaviorInstruction.dynamic(host, viewModel, viewFactory));
controller.automate();
viewSlot.removeAll();
viewSlot.add(controller.view);
return controller;
}
示例2: bind
/**
* Binds the replaceable to the binding context and override context.
* @param bindingContext The binding context.
* @param overrideContext An override context for binding.
*/
bind(bindingContext, overrideContext) {
if (this.view === null) {
this.view = (this.viewFactory as any).create();
this.viewSlot.add(this.view);
}
this.view.bind(bindingContext, overrideContext);
}
示例3: compile
compile(element: HTMLElement, fragment: Element | DocumentFragment | string, context: any, overrideContext: any = undefined) {
element.classList.remove('au-target');
let view = this.viewCompiler.compile(fragment, this.resources).create(this.container);
let viewSlot = new ViewSlot(element, true, undefined);
viewSlot.add(view);
viewSlot.bind(context, overrideContext);
viewSlot.attached();
return viewSlot;
}
示例4: ViewSlot
return this.viewEngine.loadViewFactory(templateUrl).then(x => {
let view = x.create(this.container);
let viewSlot = new ViewSlot(element, true, undefined);
viewSlot.add(view);
viewSlot.bind(ctx, undefined);
viewSlot.attached();
return viewSlot;
});
示例5: _show
/**
* @internal
*/
_show() {
if (this.showing) {
// Ensures the view is bound.
// It might not be the case when the if was unbound but not detached, then rebound.
// Typical case where this happens is nested ifs
if (!this.view.isBound) {
this.view.bind(this.bindingContext, this.overrideContext);
}
return;
}
if (this.view === null) {
this.view = (this.viewFactory as any).create();
}
if (!this.view.isBound) {
this.view.bind(this.bindingContext, this.overrideContext);
}
this.showing = true;
return this.viewSlot.add(this.view); // Promise or void
}