首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往
您找到你想要的搜索结果了吗?
是的
没有找到

Angular 2 表单(下)

使用 ngModel 进行双向数据绑定 接下来我们使用 ngModel 进行双向数据绑定,通过监听 DOM 事件,来实现更新组件的属性。...修改 app/site-form.component.html ,使用 ngModel 把我们的表单绑定到模型。... angular-forms 目录下创建 forms.css 文件,代码如下: forms.css 文件: .ng-valid[required], .ng-valid.required { border-left...删除掉 name 字段的数据,显示结果如下所示: 添加一个网站 接下来我们创建一个用于添加网站的表单, app/site-form.component.html 添加一个按钮: app/site-form.component.html...通过 ngSubmit 来提交表单 我们可以使用 Angular 的指令 NgSubmit 来提交表单, 并且通过事件绑定机制把它绑定到 SiteFormComponent.submit() 方法上。

1.6K10

AngularDart4.0 指南- 表单 顶

一路上你将学习如何: 用组件和模板构建一个Angular表单。 使用ngModel创建读取和写入输入控制值的双向数据绑定。 跟踪状态变化和表单控件的有效性。...你还没有使用Angular。 没有绑定或额外的指令,只是布局。 模板驱动的表单中,如果已经导入了angular_forms库,则不必为了使用库功能而对标记执行任何操作。...您在内部维护该列表(HeroFormComponent中)。 您将在表单中添加一个select,并使用ngFor(先前“显示数据”页面中看到的一种技术)将选项绑定到powers列表。...p模板输入变量每次迭代中是不同的power; 您使用插值语法显示其名称。 与ngModel的双向数据绑定 现在运行应用程序有点令人失望。 ? 你没有看到英雄数据,因为你还没有绑定到英雄。...Alter Ego和Hero Power上添加类似的[(ngModel)]绑定和ngControl指令。 用model替换诊断绑定表达式。 通过这种方式,您可以确认双向数据绑定适用于整个英雄模型。

17.4K30

Angular 从入坑到挖坑 - 表单控件概览

表单验证 指令 函数 表单数据发生变更时,模板驱动表单通过修改 ngModel 绑定的数据模型来完成数据更新,而响应式表单在表单数据发生变更时,FormControl 实例会返回一个新的数据模型,...而不是直接修改原来的数据模型 4.2、模板驱动表单 通过使用表单的专属指令(例如 ngModel 进行双向数据绑定)将数据值和一些对于用户的行为约束(某个字段必须填啊、某个字段长度超过了长度限制啊)绑定到组件的模板中...,并使用 ngModel 完成组件与模板之间的数据双向绑定 姓名:...使用 ngModel 进行模板绑定时,angular form 标签上自动附加了一个 NgForm 指令,因为 NgForm 指令会控制表单中带有 ngModel 指令和 name 属性的元素,而...name 属性则是 angular 用来注册控件的 key,所以表单中使用 ngModel 进行双向数据绑定时,必须要添加 name 属性 4.2.2、跟踪表单控件的状态 表单中使用 ngModel

18.9K20

Angular 内容投影

介绍 content projection 之前,我们先来观察一下以下的表单。对于同一个系统来说,下面的两个表单的区别在于使用不同的标题。...答案是可以的, Angular 中引入了内容投影的概念,即通过使用 指令来实现内容投影的功能。 ?...下面我们来介绍组件内部,如何获取 投射的内容。 Angular 中提供了 ContentChild 装饰器来获取投影的元素。...因此,投影内容的生命周期将被绑定到它被声明的地方,而不是显示地方。 这种行为有两个原因:期望一致性和性能。什么 “期望的一致性” 意味着作为开发人员,可以基于应用程序的代码,猜测其行为。...将组件的生命周期被绑定到我们的应用程序组件而不是包装器的意义是,开发者可以掌控计数器只被实例化一次,而不用了解第三方库的内部代码。 性能的原因更为重要。

2.5K20

AngularDart4.0 英雄之旅-教程-03英雄编辑器

', 刷新浏览器,页面将显示标题和英雄名 双大括号是Angular插值绑定语法。 这些插值绑定将组件的标题和英雄属性值作为字符串显示HTML标题标签内。..."name"> [(ngModel)]是将hero.name属性绑定到文本框的Angular语法。...数据两个方向流动:从属性到文本框,从文本框返回到属性。 表单和模板语法页面中阅读有关ngModel的更多信息。 @Component(指令:...)...[(ngModel)]="hero.name" ^^^^^^^^^^^^^^^^^^^^^^^ 虽然NgModelangular_forms库中定义的有效Angular指令,但默认情况下不可用。...您使用内置的ngModel指令向元素添加了双向数据绑定。 此绑定显示Hero的名称,并允许用户更改它。

3.2K10

AngularDart4.0 指南- 模板语法二 顶

使用HTML表单元素(如和)的双向绑定会很方便。 但是,没有原生HTML元素遵循x值和xChange事件模式。...幸运的是,Angular NgModel指令是一个使元素形成双向绑定的桥梁。 内置指令 早期版本的Angular包含了七十多个内置指令。 社区贡献了更多,并且为内部应用程序创建了无数私人指令。...Angular中你不需要这些指令。 通常,您可以使用功能更强大,表现力更强的Angular绑定系统获得相同的结果。 当你可以写一个简单的绑定时为什么要创建一个指令来处理点击呢?...NgModel - 与[(ngModel)]形成元素的双向绑定 开发数据输入表单时,通常都会显示数据属性,并在用户进行更改时更新该属性。 使用NgModel指令进行双向数据绑定使得这一切变得简单。...您不需要为您编写的Angular组件添加值存取器,因为您可以将值和事件属性命名为适合Angular基本的双向绑定语法,并完全跳过NgModel。上面显示的sizer是这种技术的一个例子。

29.9K20

AngularDart4.0 指南-体系结构概述 顶

HeroDetailComponent(代码显示)显示关于特定英雄的详情,这是用户从HeroListComponent提供的列表中选择的英雄。...当用户点击英雄的名字时,(click)事件绑定调用组件的selectHero方法。 双向数据绑定是一个重要的第四种形式,它使用ngModel指令将属性和事件绑定在一个符号中。..."> 双向绑定中,与属性绑定一样,数据属性值将从组件输入到输入框中。...用户的更改也会返回到组件,将属性重置为最新值,就像事件绑定一样。 Angular每个JavaScript事件循环中处理所有数据绑定,从应用程序组件树的根到所有子组件。 ?...模板中,它们看起来像常规的HTML属性,因此也就是名称。 实现双向数据绑定ngModel指令是一个属性指令的例子。

7.9K30

Angular Input和Output

实际应用场合,我们主要用来实现父组件向子组件传递数据。Angular 应用是由各式各样的组件组成,当应用启动时,Angular 会从根组件开始启动,并解析整棵组件树,数据由上而下流下下一级子组件。...: 模型 -> 视图数据绑定 视图 -> 模型事件绑定 Angular 中 [] 实现了模型到视图的数据绑定,() 实现了视图到模型的事件绑定。...当 Angular 解析模板时,遇到 [(modelName)] 形式的绑定语法,它会期待这个指令中会存在一个名为 modelName 的输入属性和一个名为 modelNameChange 的输出属性...ngModel 使用过 Angular 1.x 的读者,应该很熟悉 ng-model 这个指令,我们通过它来实现数据的双向绑定。那么 Angular 中有对应的指令么 ?...ngModel双向绑定示例 import { Component } from '@angular/core'; @Component({ selector: 'exe-app', template

2.3K50

Angular—都2019了,你还对双向数据绑定念念不忘

于是乎,goolge2016年推出了angular彻底改变了检测机制,这次并没有大力吆喝双向数据绑定,但仍会有人习惯的问一句,“有没双向数据绑定?”。如果你只是随口一问,我会告诉你,有。...Angular中的写法: // component.ts ... name = 'John'; ......Angular中的’双向数据绑定‘ 没有黑魔法 Angular努力拥抱web标准,不创造新名词,也不使用什么黑魔法,那么双向绑定是如何实现的呢?事实上通过属性绑定和事件,这并不难做到。...不看源码的情况下,如果是让你去实现 ngModel 这个指令,相信你肯定有思路。 肯定要把输入属性 ngModel 和input元素的value值关联起来。...输入+输出===双向绑定 现在,我们只需要使用简写写法把它们合起来,这就是‘双向绑定’ 为什么这样写组件中的数据会被修改?

4.3K30

angular知识点梳理第二篇-基本语法

文章目录 前文回顾 基本语法 常见指令 NgModel NgFor NgIf Ng-container 管道 前文回顾 前面已经写了关于angular项目的基本介绍和如何创建一个angular项目,这一篇主要梳理一些...angular的基本语法,这样有利于后面我们进行梳理别的知识点做一些铺垫 基本语法 常见指令 NgModel NgModel就和vue中的v-model的效果是一致的,只是写法会有一些区别,vue中是可以直接进行使用的...,但是angular中我们引入框架的一个核心模块FormsModule才可以,该指令就是将数据驱动视图的改变!...app.modules.ts中引入forms模块 // 核心模块 import { NgModule } from '@angular/core'; //引入forms模块实现数据的双向绑定 import...-- [(ngModel)] 是angular绑定数据的语法 --> <!

2.5K30
领券