原文链接

Understanding ViewChildren, ContentChildren, and QueryList in Angular

使用场景

有时候,我们想要在父组件中访问它的子组件。在Angular中可以使用ViewChildren ViewChild ContentChildren 来实现对子组件的访问。

假设,我们封装了一个Alert子组件

// alert.component.html
<h1 (click)="alert()">{{type}}</h1>
import { Component, OnInit, Input } from '@angular/core';

@Component({
selector: 'app-alert',
templateUrl: './alert.component.html',
styleUrls: ['./alert.component.scss']
})
export class AlertComponent implements OnInit { @Input() type = 'success';
constructor() { } ngOnInit() {
} alert() {
console.log('alert');
} }

然后,在HomeComponent 使用它多次

// home.component.html
<app-alert></app-alert>
<app-alert type="info"></app-alert>
<app-alert type="danger"></app-alert>

ViewChildren

使用 @ViewChildren decorator 来获取所有的子组件。@ViewChildren 支持的参数包括 directivecomponent type 和 模板变量。

// home.component.js

export class HomeComponent implements OnInit, AfterViewInit {
@ViewChildren(AlertComponent) alerts: QueryList<AlertComponent>; ngAfterViewInit() {
console.log(this.alerts);
this.alerts.forEach(alertInstance => console.log(alertInstance));
}
}

控制台打印出了3个AlertComponent的instance 对象

@ViewChildren的参数是 component 或者 directive时,会返回component 或者 directive的实例对象。

@ViewChildren的参数是模板变量时,会分两种情况。如果模板变量对应的是一个component,则返回实例对象;如果模板变量对应的是一个普通html标签,则返回本地元素的引用 ElementRef

// home.component.html
<div class="col" #div>
<app-alert #alert1></app-alert>
<app-alert type="info"></app-alert>
<app-alert type="danger"></app-alert>
</div>
// home.component.ts
export class HomeComponent implements OnInit, AfterViewInit {
@ViewChildren('alert1') alerts: QueryList<any>;
@ViewChildren('div') div: QueryList<any>; ngAfterViewInit() {
console.log(this.div);
this.div.forEach(inst => console.log(inst));
console.log(this.alerts);
this.alerts.forEach(alertInstance => console.log(alertInstance));
}
}

需要注意的是:如果使用了 *ngIf 来控制子组件是否显示,只有在子组件显示的时候,才能够获取到子组件。

ViewChild

如果在父组件中只有一个子组件,使用@ViewChild比较合适。

// home.component.ts
export class HomeComponent implements OnInit, AfterViewInit {
@ViewChild('alert1') alerts: any;
@ViewChild('div') div: any; ngAfterViewInit() {
console.log(this.div);
console.log(this.alerts);
}
}

read 参数

ElementRef

如果不想获取子组件的实例,只想访问Dom元素,可以添加read参数

// home.component.ts
@ViewChild('alert1', {read: ElementRef}) alerts: any;

@ViewChildren也支持read 参数。

ViewContainerRef

You need this token when you need to create templates or components dynamically。当需要动态创建组件时,需要这个参数。

  @ViewChildren(AlertComponent, {read: ViewContainerRef}) alerts: QueryList<AlertComponent>;

Angular5 父组件获取子组件实例( ViewChildren、ViewChild用法)的更多相关文章

  1. Vee-validate 父组件获取子组件表单校验结果

    vee-validate 是为 Vue.js 量身打造的表单校验框架,允许您校验输入的内容并显示对应的错误提示信息.它内置了很多常见的校验规则,可以组合使用多种校验规则,大部分场景只需要配置就能实现开 ...

  2. 子组件获取父组件数据 propsDown, 父组件获取子组件数据 eventUp

    (一) popsDowm 三种方法获取父组件数据:被动获得(1):主动获取(2). 1.被动获得: 父组件:v-bind: 绑定变量参数和方法参数:子组件:props 接收参数.可以在模板中直接使用也 ...

  3. vue父组件获取子组件页面的数组 以城市三级联动为例

    父组件调用子组件 <Cselect ref="registerAddress"></Cselect> import Cselect from '../../ ...

  4. 关于Vue中,父组件获取子组件的数据(子组件调用父组件函数)的方法

    1. 父组件调用子组件时,在调用处传给子组件一个方法 :on-update="updateData"   2. 子组件在props中,接收这个方法并声明 props: { onUp ...

  5. React Hook父组件获取子组件的数据/函数

    我们知道在react中,常用props实现子组件数据到父组件的传递,但是父组件调用子组件的功能却不常用.文档上说ref其实不是最佳的选择,但是想着偷懒不学redux,在网上找了很多教程,要不就是hoo ...

  6. antd 父组件获取子组件中form表单的值

    还是拿代码来讲吧,详情见注释 子组件 import React, { Component } from 'react'; import { Form, Input } from 'antd'; con ...

  7. vue 的父组件和子组件互相获取数据和方法

    父组件主动获取子组件的数据和方法 一.ref(但不能实时更新获取) 1.调用子组件的时候 定义一个ref <child ref="headerChild"></c ...

  8. vue3 template refs dom的引用、组件的引用、获取子组件的值

    介绍 通过 ref() 还可以引用页面上的元素或组件. DOM 的引用 <template> <div> <h3 ref="h3Ref">Tem ...

  9. vue:父子组件间通信,父组件调用子组件方法进行校验子组件的表单

    参考: ElementUI多个子组件表单的校验管理:https://www.jianshu.com/p/541d8b18cf95 Vue 子组件调用父组件方法总结:https://juejin.im/ ...

随机推荐

  1. 扩展Puppet – 建立Puppet CA集群

    扩展Puppet – 建立Puppet CA集群  (1 votes, average: 5.00 out of 5) 588 views 2012 年 3 月 4 日Puppet.运维ca.mast ...

  2. hiho #1032: 最长回文子串

    #1032 : 最长回文子串 时间限制:1000ms 单点时限:1000ms 内存限制:64MB 描述 小Hi和小Ho是一对好朋友,出生在信息化社会的他们对编程产生了莫大的兴趣,他们约定好互相帮助,在 ...

  3. Python 文件I/O Ⅳ

    Python里的目录: 所有文件都包含在各个不同的目录下,不过Python也能轻松处理.os模块http://www.xuanhe.net/有许多方法能帮你创建,删除和更改目录. mkdir()方法 ...

  4. python 可更改(mutable)与不可更改(immutable)对象

    在 python 中,strings, tuples, 和 numbers 是不可更改的对象,而 list,dict 等则是可以修改的对象. 不可变类型:变量赋值 a=5 后再赋值 a=10,这里实际 ...

  5. SpringBoot项目中,异常拦截

    SpringBoot自带异常拦截@ControllerAdvice 1.创建一个SellerExceptionHandler类打上@ControllerAdvice标签 @ControllerAdvi ...

  6. 【BZOJ3261】最大异或和(可持久化Trie)

    题意: 思路:可持久化Trie板子题,支持序列插入和询问 #include<bits/stdc++.h> using namespace std; typedef long long ll ...

  7. python之timeit模块

    timeit模块: timeit 模块定义了接受两个参数的 Timer 类.两个参数都是字符串. 第一个参数是你要计时的语句或者函数. 传递给 Timer 的第二个参数是为第一个参数语句构建环境的导入 ...

  8. redis安装成功后get: command not found

    安装redis后客户端无法使用,即redis-cli执行后报找不到的错误. 这主要是安装redis的时候没有把客户端装上,在StackOverFlow上找到了一种只安装redis cli的方法. 安装 ...

  9. 一、让自己习惯C++

    写在前面 第一遍看<Effective C++>时,在准备暑期实习生的招聘,没有时间好好地捋一下,将一些要点记录下来.现在实习回来,重读此书,并记录一些要点,为今后的复习亦或是学习铺垫. ...

  10. JQuery实现表格动态增加行并对新行添加事件

    实现功能: 通常在编辑表格时表格的行数是不确定的,如果一次增加太多行可能导致页面内容太多,反应变慢:通过此程序实现表格动态增加行,一直保持最下面有多个空白行. 效果: 一:原始页面 二:表1增加新行并 ...