美文网首页让前端飞程序员
【教程】(Angular)模版引用变量的魔法

【教程】(Angular)模版引用变量的魔法

作者: 吃不了辣椒 | 来源:发表于2019-03-16 18:07 被阅读3次

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

原文链接:https://blog.angulartraining.com/tutorial-the-magic-of-template-reference-variables-3183f0a0d9d1
作者:Alain Chautard
译者:而井

图片描述

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

<input #phone placeholder="phone number">

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

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

<!-- phone指向输入框元素 --> 
<button (click)="callPhone(phone.value)">Call</button>

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

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

在组件上也奏效吗?

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

@Component({
  selector: 'app-hello',
  template: `
    <div>
      <h2>Hello {{name}}</h2>
    </div>
  `
})
export class HelloComponent {

   name = 'Angular';
}

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

<app-hello #helloComp></app-hello>

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

<app-hello #helloComp></app-hello>
<!-- 下面这个表达式将会显示(文本)"Angular" -->
{{helloComp.name}}

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

对指令也奏效吗?

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

<form (ngSubmit)="onSubmit(myForm)" #myForm="ngForm">

在上面的例子里,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: `
    <form #f="ngForm" (ngSubmit)="onSubmit(f)" novalidate>
      <input name="first" ngModel required #first="ngModel">
      <input name="last" ngModel>
      <button>Submit</button>
    </form>
    
    <p>First name value: {{ first.value }}</p>
    <p>First name valid: {{ first.valid }}</p>
    <p>Form value: {{ f.value | json }}</p>
    <p>Form valid: {{ f.valid }}</p>
  `,
})
export class SimpleFormComp {
  onSubmit(f: NgForm) {
    console.log(f.value); // { first: '', last: '' }
    console.log(f.valid); // false
  }
}

相关文章

  • 【教程】(Angular)模版引用变量的魔法

    【翻译】【教程】模版引用变量的魔法 原文链接:https://blog.angulartraining.com/t...

  • 模版变量与过滤器

    一,模版路径总结 统一存放在与app同名的文件夹 二,模版变量 引用{{ 变量名 }}进行传递变量, 可以...

  • 03Angular模板在组件类中的引用

    在Angular中,我们可以在当前模板的任何地方使用模板引用变量 引用模板元素 @ViewChild用来在类中引用...

  • Angular中全局引用scss变量

    使用情景 项目比较复杂的时候,引用全局css样式引用路径会变得很长@import './../../../styl...

  • Python_Flask 基础2

    1模版语法 1.1 模版语法主要分为两种: 变量和标签 模版中的变量 : {{ var }} 模版中的标签:{% ...

  • day06-模版使用

    1)创建模版文件夹2)配置模版目录 3)使用模版文件 给模版文件传递数据模版变量的使用{{ 模版变量名 }}ind...

  • 三十二:Django之模版使用

    一:创建模版文件夹 二:配置模版目录 三:使用模版文件 四:给模版文件传递数据 模版变量使用:{{ 模版变量名 }...

  • python lambda表达式与闭包中的变量

    闭包 廖雪峰python教程 返回的函数引用了变量i,但它并非立刻执行。等到3个函数都返回时,它们所引用的变量i已...

  • ng-Message表单验证(一)

    angular-messages进行安装 引用:angular-messages.js 依赖:angular.mo...

  • angular4 (5)表单处理

    <1>angular表单API 注意要使用angular表单,要在app.module.ts中引入相应的模块模版式...

网友评论

    本文标题:【教程】(Angular)模版引用变量的魔法

    本文链接:https://www.haomeiwen.com/subject/kzwsmqtx.html