浅谈Angular中@ViewChild的用法

本篇文章带大家了解一下angular中@viewchild,介绍一下@viewchild的使用方法。

浅谈Angular中@ViewChild的用法

简单来说

个人对@ViewChild的理解就是:它是一个指代,可以通过这个指代,得到这个组件或者元素。并且我们可以使用得到的这个组件的值和方法。【相关教程推荐:《angular教程》】

为了更直观的知道它是做什么,直接上代码

通过@ViewChild获取子组件,得到子组件的值、调用子组件的方法

子组件child

content:'Zita';changeChildCon() {this.content = 'Zita1111'}

登录后复制

父组件parent

htmltsimport { ViewChild } from '@angular/core';@ViewChild('ChildrenView', { static: true }) childrenView: any;  //ChildrenView为子组件中的#后边的值,childrenView是个名称用来指代子组件this.childrenView.content   // Zita  获取子组件中的值this.childrenView.changeChildCon()  // 执行子组件中的方法this.childrenView.content   // Zita1111

登录后复制

通过@ViewChild获取某个元素

html

我是父元素中的一个标签figure,我可以通过viewchild来获取,并且获取到我之后可以改变我的样式

登录后复制

ts

import { ViewChild, ElementRef } from '@angular/core';@ViewChild('parBele', { static: true }) eleRef: ElementRef;this.eleRef.nativeElement.style.color = 'red';  // 更改获取的dom元素的样式

登录后复制

那么,通过这段代码,你就会在页面中看到,figure标签中的字体颜色变成了红色
在这里插入图片描述

特别提醒

angular8.0之后一定要加上{ static: true } 这个属性哦,除此外,官方给这个属性的解释说明是:

元数据属性: selector – 用于查询的指令类型或名字。 read – 从查询到的元素中读取另一个令牌。 static – True to resolve query results before change detection runs, false to resolve after change detection. Defaults to false.

对于static,意思就是:如果为true,则在运行更改检测之前解析查询结果,如果为false,则在更改检测之后解析。默认false.

怎么理解呐?

主要就在于“更改检测”这个动作的发生节点。
例如,我们经常使用到的ngIf、ngShow指令,如果子组件中加入了这些指令,而同时static为true。那么,当我们去捕获指代目标时,得到的值将是undefined

至此,鄙人针对实际项目中经常用到的@ViewChild的理解到此就Over啦…与君共勉

更多编程相关知识,请访问:编程教学!!

以上就是浅谈Angular中@ViewChild的用法的详细内容,更多请关注【创想鸟】其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至253000106@qq.com举报,一经查实,本站将立刻删除。

发布者:PHP中文网,转转请注明出处:https://www.chuangxiangniao.com/p/2709672.html

(0)
上一篇 2025年3月7日 20:43:37
下一篇 2025年3月7日 20:43:46

AD推荐 黄金广告位招租... 更多推荐

相关推荐

发表回复

登录后才能评论