博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
【教程】(Angular)模版引用变量的魔法
阅读量:6343 次
发布时间:2019-06-22

本文共 2005 字,大约阅读时间需要 6 分钟。

【翻译】【教程】模版引用变量的魔法

原文链接:

作者:
译者:

模版引用变量是个好东西,它允许Angular完成许多有用的事情。我经常称这个功能为“井号语法”,因为在模版中它依赖一个简单的井号来创建对一个元素(译者注:元素包括HTML元素和组件元素)的引用:

复制代码

上述的语法是如此的简洁:它创建了一个指向input元素的引用,这个引用稍后可以在我的模版中使用。需要注意的是,这个(引用)变量的作用域是它所定义的整个HTML模版(的范围)(译者注:即在定义这个引用变量的HTML模版中都可以访问这个变量)。

例如,这里就是我如何用这个引用来获取输入框的值(的例子):

复制代码

注意那个phone(变量)指向了input的。所以phone(变量)持有了(相应)HTMLElement(实例对象)的任何属性和方法,如id、name、innerHTML、value等。

上述是一种避免使用ngModel或其他数据绑定的好方法,(因为)这种方法在校验方面上不需要写太多代码。

在组件上也奏效吗?

答案就是可以奏效!假设我们有HelloWorldComponent如下:

@Component({  selector: 'app-hello',  template: `    

Hello {
{name}}

`})export class HelloComponent { name = 'Angular';}复制代码

现在按照如下代码,我们使用了“井号语法”得到了组件的引用:

复制代码

它(模版引用变量)一个最好的地方就是我们可以获取实际上的组件实例对象HelloWorldComponent。所以我们可以访问这个组件的任何方法或属性,即使他们(的权限)是声明为私有或保护的,多么令人惊喜:

{
{helloComp.name}}复制代码

我们不仅可以通过这种语法来读取一个组件的数据,而且也能修改它。

对指令也奏效吗?

当然(可以),不过这里需要进一步了解它(模版引用变量)。大部分的指令将会被作为(译者注:HTML或组件标签)的属性来使用,这意味着我们无法在那里真正应用“井号语法”,除非我们使用相同的语法进行扭转:

复制代码

在上面的例子里,myForm是一个指向(应用于表单的)ngForm指令的引用。

现在如果你细看上面的HTML元素,你可能会想:“等一下,那里并没有ngForm指令!我没有见过任何属性叫ngForm的!”,你(如果)这样想就对了。

答案就在ngForm指令的中:

@Directive({  selector: 'form:not([ngNoForm]):not([formGroup]),ngForm,[ngForm]',  ...  exportAs: 'ngForm'})复制代码

看到那个指令的选择器的了没?它(指令)将应用于任何没有ngNoFormformGroup属性的form表单元素之上。因此,ngForm指令将自动应用于我的form元素之上。

第二个被注意到的趣事就是装饰器中的exportAs属性。它告诉Angular:“嘿,如果有人想用模版引用变量来指向这个指令,(那么指令的)名字就叫做ngForm”。

现在我们已经知道它是如何运作的了。我们可以创建定制指令,并通过一个叫exportAs的来暴露该指令。

译者附

为了方便大家理解模版引用变量对指令的操控,我把相关链接的核心演示代码附在本文最后面。

import {Component} from '@angular/core';import {NgForm} from '@angular/forms'; @Component({  selector: 'example-app',  template: `    

First name value: {

{ first.value }}

First name valid: {

{ first.valid }}

Form value: {

{ f.value | json }}

Form valid: {

{ f.valid }}

`,})export class SimpleFormComp { onSubmit(f: NgForm) { console.log(f.value); // { first: '', last: '' } console.log(f.valid); // false }}复制代码

转载地址:http://pcyla.baihongyu.com/

你可能感兴趣的文章
Percona Server安装
查看>>
函数为左边表达式
查看>>
读书杂谈一
查看>>
winform listbox 元素显示tooltrip
查看>>
cacti安装与配置
查看>>
TF-IDF与余弦相似性的应用(一):自动提取关键词
查看>>
javascript面向对象2
查看>>
限制容器对CPU的使用 - 每天5分钟玩转 Docker 容器技术(28)
查看>>
jquery 实现的一个 随机云标签网页背景
查看>>
RPC
查看>>
android广播事件处理broadcast receive
查看>>
在eclipse 里面 修改tomcat的配置--Server Locations
查看>>
网站 mvc url 路径 设置 为 *.html 的原因
查看>>
mybatis 开启使用 默认的 二级缓存
查看>>
docker 容器 创建和 使用
查看>>
SQLITE使用指南
查看>>
用Maven部署war包到远程Tomcat服务器
查看>>
android字体大小的设置
查看>>
2015.06.04 工作任务与心得
查看>>
icinga2使用587端口发邮件
查看>>