详解Angular模板引用变量及其作用域
Angular模板引用变量
如果你曾经参与过Angular项目的开发,那么你可能一眼就会看出谁将是本文的主角
<input type="text" [value]="value" #name>
若你对此陌生,也无须在意。示例代码的<input>标签的属性中存在一个画风明显与其他属性不同的家伙——#name,这种以一个#开头命名,被附加在DOM元素上的属性,被称为模板引用变量(template reference variables)。
那么何为模板引用变量呢?文档是这样描述的
A template reference variable is often a reference to a DOM element within a template. It can also be a reference to an Angular ponent or directive or a web ponent.
模板引用变量可以是Angualr模板中的DOM元素、Angular组件(指令),甚至Web组件的引用,而它具体是什么,则取决于它所依附的元素(不使用指令进行干预时)。如前文示例代码中的模板引用变量name就是<input>这一DOM元素的引用。
既然模板引用变量是模板中某一元素的引用,那理所地我们便可以通过这个引用变量" 触及 "该模板元素的" 实体 "。这在实际地开发中是十分实用的,考虑以下代码
<app-ponent #ponent [input]="variable"></app-ponent> {{ ponent.input }} {{ ponent.func() }}
通过模板引用变量我们获得了app-ponent组件的实例引用,这使得我们可以轻松地在模板中访问app-ponent组件内部的成员。在某些情境下,这种能力给我们的开发提供了很大的助力。
模板引用变量的作用域
You can refer to a template reference variable anywhere in the template.
在文档中,官方毫不含糊地向我们表示模板引用变量可以在模板中的任何地方使用。最骚的是,“任何地方”还被特别加粗。我们在大多数的时候,并不会对这句话产生疑问,但也许某天你会怀疑这个anywhere是否真实。有如下的代码
<app-card> <ng-template #body> <app-ponent #ponent [input]="variable"></app-ponent> </ng-template> <ng-template #footer> {{ponent.input}} </ng-template> </app-card>
当代码运行后,我们将会在控制台看到这样的错误提示
TypeError: Cannot read property 'input' of undefined
为什么ponent会是undefined?
答案其实很明显,模板引用对象可以在模板中的任何地方使用,但此例中ponent的定义与使用却并不在一个template中。文档中所描述的 template 并不能直接与 组件的模板文件 划上等号。当我们使用ng-template时,会在当前模板的内部再建立一个新的模板,它的内部无法直接被外部模板触及,示例中的ponent.input自然会引起错误。
当 template 的定义明确以后,一切都是如此简单模板引用变量存在作用域,其作用域是它所处的 template,而非它所在的模板文件,它可以在其作用域内的任何地方被使用。
,我们再看一个例子
<div ngIf="true"> <app-ponent #ponent [input]="variable"></app-ponent> </div> {{ponent.input}}
当这段代码运行后,我们依旧会在控制台看到
TypeError: Cannot read property 'input' of undefined
至于背后的原因,我便作为小小的悬念留给大家,由大家自己去了解。以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持狼蚁SEO。
编程语言
- 如何快速学会编程 如何快速学会ug编程
- 免费学编程的app 推荐12个免费学编程的好网站
- 电脑怎么编程:电脑怎么编程网咯游戏菜单图标
- 如何写代码新手教学 如何写代码新手教学手机
- 基础编程入门教程视频 基础编程入门教程视频华
- 编程演示:编程演示浦丰投针过程
- 乐高编程加盟 乐高积木编程加盟
- 跟我学plc编程 plc编程自学入门视频教程
- ug编程成航林总 ug编程实战视频
- 孩子学编程的好处和坏处
- 初学者学编程该从哪里开始 新手学编程从哪里入
- 慢走丝编程 慢走丝编程难学吗
- 国内十强少儿编程机构 中国少儿编程机构十强有
- 成人计算机速成培训班 成人计算机速成培训班办
- 孩子学编程网上课程哪家好 儿童学编程比较好的
- 代码编程教学入门软件 代码编程教程