在angular组件中数据交互主要有下面几种
1、父组件通过属性绑定到子组件,子组件通过事件传递参数到父组件2、父组件通过局部变量获取子组件的引用3、父组件使用@ViewChild获取子组件的引用4、两个不相关联的组件使用中间人模式交互5、终极大招:创建一个服务注入到组件中 6、直接把父组件当做服务注入到子组件中子组件中通过emit将要传递出去的参数传递给父组件,父组件中就可以获取到
在angular中使用局部模板变量可以获取到子组件的实例引用 模板局部变量的定义是使用#name
//父组件html代码 <li *ngFor="let item of dataSet"> //使用模板局部变量调用子类的方法 <app-child [names] = "item" (click)="father.childFn()" #father></app-child> </li> //父组件的ts代码 dataSet = [ {"id":0,"name":"张三"}, {"id":1,"name":"李四"} ] //子组件的ts代码 @Input() names: any = {} childFn(){ console.log("我是子类的方法"); } //子组件的html代码 <span>{{names.name}}</span>这种方法跟使用模板局部变量一样的,都是在父组件中调用子组件的方法 子组件跟上面方法一样的
//父组件ts文件 dataSet = [ {"id":0,"name":"张三"}, {"id":1,"name":"李四"} ] //@ViewChild(子组件名称) 随便命名:子组件名称 @ViewChild(ChildComponent) child:ChildComponent; father(){ //调用子组件方法 this.child.childFn(); } //父组件html代码 <li *ngFor="let item of dataSet"> <app-child [names] = "item" (click)="father()"></app-child> </li>中间人模式就是第一种方式的改版,如果两个组件没有父子关系,那么久查找他们共同的父组件,我们知道angular是有一个根组件组成的组件树,那么至少有根组件可以使用的。 现在要实现从组件com1点击按钮传递参数到组件com2中 具体代码如下:
//com1组件html代码 <div class="com1"> <p>我是com1组件</p> <input type="button" value="com1按钮" (click)="com1Fn($event)" /> </div> //com1组件ts代码 //创建一个输出 @Output() outcom1Fn = new EventEmitter<string>(); com1Fn(){ this.outcom1Fn.emit("我是com1组件的"); } //根组件作为中间者模式代码 //中间者ts文件 private com1Tocom2; //根组件作为中间者 appFn(event:any){ console.log(event); this.com1Tocom2 = event; } //中间者html代码 <app-com1 (outcom1Fn)="appFn($event)"></app-com1> <app-com2 [com2]="com1Tocom2"></app-com2> //com2组件ts代码 @Input() com2:string = ""; //com2组件的html代码 <div class="com2"> <p>我是com2组件</p> <p>我是com1组件传递过来的:{{com2}}</p> </div>总结说明:angular项目有时候运行没效果,自己觉得代码没错,那么请重启下服务
在父组件传递数据到子组件中,子组件接受数据,可以对其接收的数据进行处理后再显示在页面中,这里就要用到set与get方法
//父组件ts文件,传递一个parent给子组件 data:string = "parent"; //父组件html代码 <app-comdemo01 [input]="data"></app-comdemo01> //子组件ts文件 export class Comdemo01Component implements OnInit { _input: string; @Input() public set input(v: string) { this._input = v.toUpperCase();//转换大写输出 console.log(v); } public get input(): string { return this._input; } constructor() { } ngOnInit() { } } //子组件html代码 I am fron {{input}}