1. 

10年积累的网站制作、成都做网站经验,可以快速应对客户对网站的新想法和需求。提供各种问题对应的解决方案。让选择我们的客户得到更好、更有力的网络服务。我虽然不认识你,你也不认识我。但先建设网站后付款的网站建设流程,更有平坝免费网站建设让你可以放心的选择与我们合作。
import { Component, TemplateRef, ViewContainerRef, ViewChild,
 AfterViewInit } from '@angular/core';
@Component({
 selector: 'app-code404',
 template: `
 
  
   Big Keriy !
   
 `,
})
export class Code404Component implements AfterViewInit{
 // @ViewChild 装饰器获取模板元素
 @ViewChild('tpl')
 tplRef: TemplateRef;
 constructor(private vcRef: ViewContainerRef) {}
 ngAfterViewInit() {
  // 使用ViewContainerRef对象的createEmbeddedView方法创建内嵌视图。
  this.vcRef.createEmbeddedView(this.tplRef);
 } }
 这样其实我们在视图中就得到了一个什么...啊,就是一个'Big Keriy !'的字符串。
2. ngTemplateOutlet指令
a. ngTemplateOutlet
和routerOutlet是一个意思,将视图(
import { Component } from '@angular/core';
 @Component({
  selector: 'app-code404',
  template: `
   
    Hello, Semlinker!
    
   
    Big Keriy !
    
   
   
`, })
 export class Code404Component { }最终的视图应该是:
Big Keriy !
Hello, Semlinker!
b. ngOutletContex
看名字就知道意思。
ngTemplateOutlet指令基于TemplateRef对象,在使用ngTemplateOutlet指令时,可以通过ngTemplateOutletContext属性来设置来设置EmbeddedViewRef的上下文对象。可以使用let语法来声明绑定上下文对象属性名。
import { Component, TemplateRef, ViewContainerRef, ViewChild,
 AfterViewInit } from '@angular/core';
@Component({
 selector: 'app-code404',
 template: `
  
  
   {{message}}
   
  
  
   {{msg}}
   
  
  
   {{msg}}
   
  
  
  
  
  
  
 `,
})
export class Code404Component implements AfterViewInit{
 @ViewChild('tpl')
 tplRef: TemplateRef;
 constructor(private vcRef: ViewContainerRef) {}
 ngAfterViewInit() {
  this.vcRef.createEmbeddedView(this.tplRef);
 }
 context = { message: 'Hello ngOutletContext!',
  $implicit: 'great, Semlinker!' };
  // 这里的$implicit是固定写法
}
 先看输出的视图:
Hello ngOutletContext!
Hello ngOutletContext!
Hello, Semlinker!
3. ngComponentOutlet指令
听着名字就很爽,这不是插入视图的,是插入组件的!
该指令使用声明的方式,动态加载组件。
先写组件,里面有两个。。组件:
 @Component({
  selector: 'alert-success',
  template: `
   Alert success
  `,
 })
 export class AlertSuccessComponent { }
 @Component({
  selector: 'alert-danger',
  template: `
   Alert danger
  `,
 })
 export class AlertDangerComponent { }
 @Component({
  selector: 'my-app',
  template: `
   Angular version 4
   当然,还需要在模块中声明入口:
// app.module.ts
@NgModule({
  // ...
  declarations: [
   AppComponent,
   SignUpComponent,
   AlertSuccessComponent,
   AlertDangerComponent
  ],
  entryComponents: [    // 这里面写指令中呀用到的组件
   AlertSuccessComponent,
   AlertDangerComponent
],
// ...
})
这样就可以使用ngComponentOutlet指令来插入组件玩耍了:
这是一个完整语法简单的例子:
// ...
@Component({
 selector: 'ng-component-outlet-complete-example',
 template: `
  4. 创建结构指令
也想不出来一个什么好例子,抄一个例子过来:
// uless.directive.ts
import { Directive, Input, TemplateRef, ViewContainerRef } from '@angular/core';
 @Directive({
   selector: '[exeUnless]'
 })
 export class UnlessDirective {
   @Input('exeUnless')
   set condition(newCondition: boolean) { // set condition
     if (!newCondition) {
       this.viewContainer.createEmbeddedView(this.templateRef);
     } else {
       this.viewContainer.clear();
     } 
   }
   constructor(private templateRef: TemplateRef,
     private viewContainer: ViewContainerRef) {
   } 
 }
 import { Component } from '@angular/core';
 @Component({
  selector: 'app-root',
  template: `
   Hello, Semlinker!
  `,
 })
 export class AppComponent {
  condition: boolean = false;
 }
 // app.component.ts
 import { Component } from '@angular/core';
 @Component({
  selector: 'app-root',
  template: `
   Hello, Semlinker!
  `,
 })
 export class AppComponent {
  condition: boolean = false;
 }
 以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持创新互联。
分享题目:详解Angular自定义结构指令
标题来源:http://www.cqwzjz.cn/article/pjhgch.html

 建站
建站
 咨询
咨询 售后
售后
 建站咨询
建站咨询 
 