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


TypeScript container.Registry類代碼示例

本文整理匯總了TypeScript中@ember/-internals/container.Registry的典型用法代碼示例。如果您正苦於以下問題:TypeScript Registry類的具體用法?TypeScript Registry怎麽用?TypeScript Registry使用的例子?那麽, 這裏精選的類代碼示例或許可以為您提供幫助。


在下文中一共展示了Registry類的3個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的TypeScript代碼示例。

示例1: setupApplicationRegistry

export function setupApplicationRegistry(registry: Registry) {
  registry.injection(
    'service:-glimmer-environment',
    'appendOperations',
    'service:-dom-tree-construction'
  );
  registry.injection('renderer', 'env', 'service:-glimmer-environment');

  // because we are using injections we can't use instantiate false
  // we need to use bind() to copy the function so factory for
  // association won't leak
  registry.register('service:-dom-builder', {
    create({ bootOptions }: { bootOptions: { _renderMode: string } }) {
      let { _renderMode } = bootOptions;

      switch (_renderMode) {
        case 'serialize':
          return serializeBuilder.bind(null);
        case 'rehydrate':
          return rehydrationBuilder.bind(null);
        default:
          return clientBuilder.bind(null);
      }
    },
  });
  registry.injection('service:-dom-builder', 'bootOptions', '-environment:main');
  registry.injection('renderer', 'builder', 'service:-dom-builder');

  registry.register(P`template:-root`, RootTemplate);
  registry.injection('renderer', 'rootTemplate', P`template:-root`);

  registry.register('renderer:-dom', InteractiveRenderer);
  registry.register('renderer:-inert', InertRenderer);

  if (hasDOM) {
    registry.injection('service:-glimmer-environment', 'updateOperations', 'service:-dom-changes');
  }

  registry.register('service:-dom-changes', {
    create({ document }: { document: Simple.Document }) {
      return new DOMChanges(document);
    },
  });

  registry.register('service:-dom-tree-construction', {
    create({ document }: { document: Simple.Document }) {
      let Implementation = hasDOM ? DOMTreeConstruction : NodeDOMTreeConstruction;
      return new Implementation(document);
    },
  });
}
開發者ID:habdelra,項目名稱:ember.js,代碼行數:51,代碼來源:setup-registry.ts

示例2: setupEngineRegistry

export function setupEngineRegistry(registry: Registry) {
  registry.register('view:-outlet', OutletView);
  registry.register('template:-outlet', OutletTemplate);
  registry.injection('view:-outlet', 'template', 'template:-outlet');

  registry.injection('service:-dom-changes', 'document', 'service:-document');
  registry.injection('service:-dom-tree-construction', 'document', 'service:-document');

  registry.register(P`template:components/-default`, ComponentTemplate);

  registry.register('service:-glimmer-environment', Environment);

  registry.register(P`template-compiler:main`, TemplateCompiler);

  registry.injection('template', 'compiler', P`template-compiler:main`);

  registry.optionsForType('helper', { instantiate: false });

  registry.register('helper:loc', loc);

  registry.register('component:-text-field', TextField);
  registry.register('component:-text-area', TextArea);
  registry.register('component:-checkbox', Checkbox);
  registry.register('component:link-to', LinkToComponent);

  if (!ENV._TEMPLATE_ONLY_GLIMMER_COMPONENTS) {
    registry.register(P`component:-default`, Component);
  }
}
開發者ID:habdelra,項目名稱:ember.js,代碼行數:29,代碼來源:setup-registry.ts

示例3: setupEngineRegistry

export function setupEngineRegistry(registry: Registry) {
  registry.register('view:-outlet', OutletView);
  registry.register('template:-outlet', OutletTemplate);
  registry.injection('view:-outlet', 'template', 'template:-outlet');

  registry.injection('service:-dom-changes', 'document', 'service:-document');
  registry.injection('service:-dom-tree-construction', 'document', 'service:-document');

  registry.register(P`template:components/-default`, ComponentTemplate);

  registry.register('service:-glimmer-environment', Environment);

  registry.register(P`template-compiler:main`, TemplateCompiler);

  registry.injection('template', 'compiler', P`template-compiler:main`);

  registry.optionsForType('helper', { instantiate: false });

  registry.register('helper:loc', loc);

  registry.register('component:-text-field', TextField);
  registry.register('component:-checkbox', Checkbox);
  registry.register('component:link-to', LinkToComponent);

  if (EMBER_GLIMMER_ANGLE_BRACKET_BUILT_INS) {
    // Internal

    // These are registered as CapCase because our internal tempaltes do not
    // go through the dashify transform. As a nice bonus, it also makes it
    // more difficult for users to invoke them by accident.
    registry.register('component:TextField', TextField);
    registry.register('component:Checkbox', Checkbox);

    // Public

    registry.register('component:input', Input);
    registry.register('template:components/input', InputTemplate);

    registry.register('component:textarea', TextArea);
  } else {
    registry.register('component:-text-area', TextArea);
  }

  if (!ENV._TEMPLATE_ONLY_GLIMMER_COMPONENTS) {
    registry.register(P`component:-default`, Component);
  }
}
開發者ID:mixonic,項目名稱:ember.js,代碼行數:47,代碼來源:setup-registry.ts


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