include ../_util-fns
:marked
  Component templates are not always fixed. An application may need to load new components at runtime.
  This cookbook shows you how to use `ComponentFactoryResolver` to add components dynamically.
  
:marked
   # Contents
      * [Dynamic component loading](#dynamic-loading)
      * [The directive](#directive)
      * [Loading components](#loading-components)
        * [Resolving Components](#resolving-components)
        * [Selector References](#selector-references)
      * [A common _AdComponent_ interface](#common-interface)
      * [Final ad banner](#final-ad-banner)
:marked
   See the 
   of the code in this cookbook.
.l-main-section
:marked
   ## Dynamic component loading
   The following example shows how to build a dynamic ad banner.
   The hero agency is planning an ad campaign with several different
   ads cycling through the banner. New ad components are added
   frequently by several different teams. This makes it impractical
   to use a template with a static component structure.
   Instead, you need a way to load a new component without a fixed
   reference to the component in the ad banner's template.
   Angular comes with its own API for loading components dynamically.
.l-main-section
:marked
   ## The directive
   Before you can add components you have to define an anchor point
   to tell Angular where to insert components.
   The ad banner uses a helper directive called `AdDirective` to
   mark valid insertion points in the template.
+makeExample('cb-dynamic-component-loader/ts/src/app/ad.directive.ts',null,'src/app/ad.directive.ts')(format='.')
:marked
  `AdDirective` injects `ViewContainerRef` to gain access to the view
  container of the element that will host the dynamically added component.
  In the `@Directive` decorator, notice the selector name, `ad-host`;
  that's what you use to apply the directive to the element.
  The next section shows you how.
.l-main-section
:marked
   ## Loading components
   Most of the ad banner implementation is in `ad-banner.component.ts`.
   To keep things simple in this example, the HTML is in the `@Component`
   decorator's `template` property as a template string.
   The `` element is where you apply the directive you just made.
   To apply the `AdDirective`, recall the selector from `ad.directive.ts`,
   `ad-host`. Apply that to `` without the square brackets. Now Angular knows
   where to dynamically load components.
+makeExample('cb-dynamic-component-loader/ts/src/app/ad-banner.component.ts', 'ad-host' ,'src/app/ad-banner.component.ts (template)')(format='.')
:marked
  The `` element is a good choice for dynamic components
  because it doesn't render any additional output.
a#resolving-components
:marked
  ### Resolving components
  Take a closer look at the methods in `ad-banner.component.ts`.
  `AdBannerComponent` takes an array of `AdItem` objects as input,
  which ultimately comes from `AdService`.  `AdItem` objects specify 
  the type of component to load and any data to bind to the 
  component.`AdService` returns the actual ads making up the ad campaign.
  Passing an array of components to `AdBannerComponent` allows for a
  dynamic list of ads without static elements in the template.
  With its `getAds()` method, `AdBannerComponent` cycles through the array of `AdItems`
  and loads a new component every 3 seconds by calling `loadComponent()`.
+makeExample('cb-dynamic-component-loader/ts/src/app/ad-banner.component.ts', 'class' ,'src/app/ad-banner.component.ts (excerpt)')(format='.')
:marked
  The `loadComponent()` method is doing a lot of the heavy lifting here.
  Take it step by step. First, it picks an ad.
.l-sub-section
    :marked
      **How _loadComponent()_ chooses an ad**
      The `loadComponent()` method chooses an ad using some math.
      First, it sets the `currentAddIndex` by taking whatever it
      currently is plus one, dividing that by the length of the `AdItem` array, and
      using the _remainder_ as the new `currentAddIndex` value. Then, it uses that
      value to select an `adItem` from the array.
:marked
  After `loadComponent()` selects an ad, it uses `ComponentFactoryResolver` 
  to resolve a `ComponentFactory` for each specific component. 
  The `ComponentFactory` then creates an instance of each component.
  Next, you're targeting the `viewContainerRef` that 
  exists on this specific instance of the component. How do you know it's 
  this specific instance? Because it's referring to `adHost` and `adHost` is the 
  directive you set up earlier to tell Angular where to insert dynamic components.
  As you may recall, `AdDirective` injects `ViewContainerRef` into its constructor. 
  This is how the directive accesses the element that you want to use to host the dynamic component. 
  To add the component to the template, you call `createComponent()` on `ViewContainerRef`.
  The `createComponent()` method returns a reference to the loaded component.
  Use that reference to interact with the component by assigning to its properties or calling its methods.
a#selector-references
:marked
  #### Selector references
  Generally, the Angular compiler generates a `ComponentFactory`
  for any component referenced in a template. However, there are
  no selector references in the templates for
  dynamically loaded components since they load at runtime.
  To ensure that the compiler still generates a factory,
  add dynamically loaded components to the `NgModule`'s `entryComponents` array:
+makeExample('cb-dynamic-component-loader/ts/src/app/app.module.ts', 'entry-components' ,'src/app/app.module.ts (entry components)')(format='.')
a#common-interface
:marked
  ### A common _AdComponent_ interface
  In the ad banner, all components implement a common `AdComponent` interface to
  standardize the API for passing data to the components.
  Here are two sample components and the `AdComponent` interface for reference:
+makeTabs(
  `cb-dynamic-component-loader/ts/src/app/hero-job-ad.component.ts,
   cb-dynamic-component-loader/ts/src/app/hero-profile.component.ts,
   cb-dynamic-component-loader/ts/src/app/ad.component.ts`,
  null,
  `hero-job-ad.component.ts,
   hero-profile.component.ts,
   ad.component.ts`
)
a#final-ad-baner
:marked
  ### Final ad banner
   The final ad banner looks like this:
figure.image-display
   img(src="/resources/images/cookbooks/dynamic-component-loader/ads.gif" alt="Ads")
:marked
   See the .