Angular 在项目中学习@ViewChild和ElementRef的使用

现在我对 @ViewChild 的了解便是,父组件中想要使用或者说操作子组件,譬如执行子组件的方法,或者说获取子组件的属性。

View就是看,Child就是孩子,看孩子,那必然是父亲看孩子

也就是说,@ViewChild 是 父组件 用来 “看” 子组件的。

@ViewChild 使用一


当ViewChild传入的是子组件ChildComponent,即在父组件中注入子组件,从而获取子组件的属性或方法

childComponent.ts

import { Component } from ‘@angular/core’;

@Component({

selector:‘app-child’,

templateurl:‘bababa’,

styleUrls:‘bababab’,

})

export class ChildComponent{

childFunction(){

console.log(‘this function is from childComponent’);

}

}

parentComponent.ts

import { Component } from ‘@angular/core’;

import { ViewChild } from ‘@angular/core’;

import { ChildComponent } from ‘…/子组件的目录’;

@Component({

selector:‘app-parent’,

templateurl:‘bababa’,

styleUrls:‘bababab’,

})

export class ParentComponent{

@ViewChild(ChildComponent) child : ChildComponent;

parentFunction(){

console.log(‘this function is from parentComponent’)

this.child.childFunction();

}

}

在父组件中,要注意别忘了准备工作,导入ViewChild和子组件

import { ViewChild } from ‘@angular/core’;

import { ChildComponent } from ‘…/子组件的目录’;

此时ViewChild传入的是子组件ChildComponent,以变量child保存

@ViewChild(ChildComponent) child : ChildComponent;

这样就可以大大方方的使用子组件里的方法了。

@ViewChild 使用二


当ViewChild传入的是字符串,子组件打了锚点,父组件通过锚点位置从而获得子组件的属性或方法

八九不离十,只不过使用子组件ChildComponent时要打锚点做标记,即:

<app-child #child>I am a childComponent

另外,在父组件ParentComponent的ts里是这么写的:

export class ParentComponent{

@ViewChild(‘child’) child : any; //找child这个锚点

parentFunction(){

console.log(‘this function is from parentComponent’)

this.child.childFunction();

}

}

小结


近期在项目中发现:对于@ViewChild的使用,更多的是使用打锚点这种方式。有可能是我接触相关项目不够多,总结的这个规律不一定很具有典型性。

当我在项目实践时,需要去找这些父子组件之间的关系,看到有锚点如:

<app-child #child>I am a childComponent

自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。

深知大多数前端工程师,想要提升技能,往往是自己摸索成长或者是报班学习,但对于培训机构动则几千的学费,着实压力不小。自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!

因此收集整理了一份《2024年Web前端开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。
img
img
img
img
img
img

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上前端开发知识点,真正体系化!

由于文件比较大,这里只是将部分目录大纲截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且后续会持续更新

如果你觉得这些内容对你有帮助,可以添加V获取:vip1024c (备注前端)
img

Vue 编码基础

2.1.1. 组件规范

2.1.2. 模板中使用简单的表达式

2.1.3 指令都使用缩写形式

2.1.4 标签顺序保持一致

2.1.5 必须为 v-for 设置键值 key

2.1.6 v-show 与 v-if 选择

2.1.7 script 标签内部结构顺序

2.1.8 Vue Router 规范

Vue 项目目录规范

2.2.1 基础

2.2.2 使用 Vue-cli 脚手架

2.2.3 目录说明

2.2.4注释说明

2.2.5 其他

CodeChina开源项目:【大厂前端面试题解析+核心总结学习笔记+真实项目实战+最新讲解视频】

设置键值 key

2.1.6 v-show 与 v-if 选择

2.1.7 script 标签内部结构顺序

2.1.8 Vue Router 规范

Vue 项目目录规范

2.2.1 基础

2.2.2 使用 Vue-cli 脚手架

2.2.3 目录说明

2.2.4注释说明

2.2.5 其他

CodeChina开源项目:【大厂前端面试题解析+核心总结学习笔记+真实项目实战+最新讲解视频】

  • 9
    点赞
  • 19
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值