當前位置: 首頁>>代碼示例>>TypeScript>>正文


TypeScript Container.createChild方法代碼示例

本文整理匯總了TypeScript中aurelia-dependency-injection.Container.createChild方法的典型用法代碼示例。如果您正苦於以下問題:TypeScript Container.createChild方法的具體用法?TypeScript Container.createChild怎麽用?TypeScript Container.createChild使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在aurelia-dependency-injection.Container的用法示例。


在下文中一共展示了Container.createChild方法的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;
}
開發者ID:aurelia,項目名稱:templating-resources,代碼行數:32,代碼來源:repeat-integration.spec.ts

示例2: it

 it('should not create new child Container if "childContainer" is provided', async done => {
   const settings = { childContainer: container.createChild() };
   spyOn(container, 'createChild').and.callThrough();
   spyOn(settings.childContainer, 'invoke').and.callThrough();
   await _success(() => dialogService.open(settings), done);
   expect(container.createChild).not.toHaveBeenCalled();
   expect(settings.childContainer.invoke).toHaveBeenCalled();
   done();
 });
開發者ID:HIRANO-Satoshi,項目名稱:dialog,代碼行數:9,代碼來源:dialog-service.spec.ts

示例3: it

 it('createForCurrentScope', () => {
   const container = new Container();
   const standardValidator = {};
   container.registerInstance(Validator, standardValidator);
   const childContainer = container.createChild();
   const factory = childContainer.get(ValidationControllerFactory);
   const controller = factory.createForCurrentScope();
   expect(controller.validator).toBe(standardValidator);
   expect(container.get(Optional.of(ValidationController))).toBe(null);
   expect(childContainer.get(Optional.of(ValidationController))).toBe(controller);
   const customValidator = {};
   expect(factory.createForCurrentScope(customValidator).validator).toBe(customValidator);
 });
開發者ID:doktordirk,項目名稱:validation,代碼行數:13,代碼來源:validation-controller-factory.ts

示例4: it

        it('should return the key from the parent container when present', () => {
            var sut = new Parent("test"),
                parent = new Container(),
                childContainer = parent.createChild(),
                instance = {},
                wrongInstance = {};

            parent.registerInstance("test", instance);
            childContainer.registerInstance("test", wrongInstance);

            var result = sut.get(childContainer);

            expect(result).toBe(instance);
            expect(result).not.toBe(wrongInstance);
        });
開發者ID:behzad888,項目名稱:DefinitelyTyped,代碼行數:15,代碼來源:metadata.spec.ts

示例5: show

  show(settings: TooltipSettings) {
    const { _container: container } = this;
    const { target, model, viewModel: tempViewModel } = settings;
    const viewModel = Origin.get(tempViewModel).moduleId;

    let host = this._renderer.getContainer();
    let instruction: CompositionContext = {
      container: this._container,
      bindingContext: {},
      overrideContext: {},
      viewResources: null,
      childContainer: this._container.createChild(),
      model: model,
      viewModel: settings.viewModel,
      viewSlot: new ViewSlot(host, true)
    };

    this._viewModel = viewModel;
    this._model = model;

    return _getViewModel(instruction, this._compositionEngine).then(returnedInstruction => {
      this._showing = invokeLifecycle(viewModel, 'canActivate', model);
      this._viewSlot = returnedInstruction.viewSlot;

      return invokeLifecycle(instruction.viewModel, 'canActivate', instruction.model)
      .then((canActivate: boolean) => {
        if (canActivate) {
          this._compositionEngine.compose(returnedInstruction)
            .then(controller => {
              this._renderer._element = host;
              this._renderer._viewSlot = returnedInstruction.viewSlot;
              this._renderer.show(settings.target);
            });
        }
      });
    });
  }
開發者ID:Thanood,項目名稱:monterey,代碼行數:37,代碼來源:tooltip-service.ts


注:本文中的aurelia-dependency-injection.Container.createChild方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。