AngularJs2 构建简单的英雄编辑器
参考上一篇文章的步骤,重新把相关环境准备、目录结构走一遍。
这一次我们要开始创建真正的Angularjs项目了。
显示我们的英雄
我们要在应用中显示英雄数据
我们来为 AppComponent
添加两个属性: title
属性表示应用的名字,而 hero
属性表示一个名叫“ Windstorm ”的英雄。
export class AppComponent {
title = 'Tour of Heroes';
hero = 'Windstorm';
}
现在,我们为这些新属性建立数据绑定,以更新 @Component
装饰器中指定的模板
template: '<h1>{{title}}</h1><h2>{{hero}} details!</h2>'
Hero 对象
此时此刻,我们的英雄还只有一个名字。显然,它 / 她应该有更多属性。 让我们把 hero
从一个字符串字面量换成一个类。
创建一个 Hero
类,它具有 id
和 name
属性。 现在,把下列代码放在 app.component.ts
的顶部,仅次于 import 语句。
在app.component.ts中添加代码以创建Hero类。
export class Hero {
id: number;
name: string;
}
现在,有了一个 Hero
类,我们就要把组件 hero
属性的类型换成 Hero
了。 然后以 1
为 id 、以“ Windstorm ”为名字,初始化它。
在AppComponent类中添加:
hero: Hero = {
id: ,
name: 'Windstorm'
};
我们把 hero
从一个字符串换成了对象,所以也得更新模板中的绑定表达式,来引用 hero
的 name
属性。
template: '<h1>{{title}}</h1><h2>{{hero.name}} details!</h2>'
添加更多的 HTML
能显示名字虽然不错,但我们还想看到这位英雄的所有属性。 我们将添加一个 <div>
来显示英雄的 id
属性,用另一个 <div>
来显示英雄的 name
属性。
template: '<h1>{{title}}</h1><h2>{{hero.name}} details!</h2><div><label>id: </label>{{hero.id}}</div><div><label>name: </label>{{hero.name}}</div>'
多行模板字符串
我们可以通过字符串加法来制作更可读的模板,但这样仍然太难看了——难于阅读,容易拼错。 这样不行!我们要借助 ES2015 和 TypeScript 提供的模板字符串来保持清爽。
把模板的双引号改成反引号,并且让 <h1>
, <h2>
和 <div>
标签各占一行。
template:` <h1>{{title}}</h1> <h2>{{hero.name}} details!</h2> <div><label>id: </label>{{hero.id}}</div> <div><label>name: </label>{{hero.name}}</div> `
编辑我们的英雄
我们想在一个文本框中编辑英雄的名字。
把英雄的名字从单纯的 <label>
重构成 <label>
和 <input>
元素的组合,就像下面这样:
template:`
<h1>{{title}}</h1>
<h2>{{hero.name}} details!</h2>
<div><label>id: </label>{{hero.id}}</div>
<div>
<label>name: </label>
<input value="{{hero.name}}" placeholder="name">
</div>
`
在浏览器中,我们看到英雄的名字显示成一个 <input>
文本框。但看起来还是有点不太对劲。 当修改名字时,我们的改动并没有反映到 <h2>
中。使用单向数据绑定,我们没法实现所期望的这种行为。
双向绑定
我们的期望是:在 <input>
中显示英雄的名字,修改它,并且在所有绑定到英雄名字的地方看到这些修改。 简而言之,我们需要双向数据绑定。
在我们让 表单输入 支持双向数据绑定之前,我们得先导入 FormsModule
模块。 只要把它添加到 NgModule
装饰器的 imports
数组中就可以了,该数组是应用中用到的外部模块列表。 这样我们就引入了表单包,其中包含了 ngModel
。
我们的模块app.module.ts就成了
import { NgModule } from '@angular/core';
import { BrowserModule } from '@angular/platform-browser';
import { FormsModule } from '@angular/forms';
import { AppComponent } from './app.component';
@NgModule({
imports: [
BrowserModule,
FormsModule
],
declarations: [
AppComponent
],
bootstrap: [ AppComponent ]
})
export class AppModule { }
接下来更新模板,加入用于双向绑定的内置指令 ngModel
。
把 <input>
替换为下列 HTML
<input [(ngModel)]="hero.name" placeholder="name">
浏览器刷新。又见到我们的英雄了。我们可以编辑英雄的名字,也能看到这个改动立刻体现在 <h2>
中。
好了,在终端中输入 npm start尽情浏览吧。
回顾一下我们刚才的操作;
我们从创建对象开始,再到在模板中显示对象的属性。以及双休绑定,关键字(ngModel),注意要写完整[(ngModel)].
AngularJs2 构建简单的英雄编辑器的更多相关文章
- 构建简单的 C++ 服务组件,第 1 部分: 服务组件体系结构 C++ API 简介
构建简单的 C++ 服务组件,第 1 部分: 服务组件体系结构 C++ API 简介 熟悉将用于 Apache Tuscany SCA for C++ 的 API.您将通过本文了解该 API 的主要组 ...
- 基于slate构建文档编辑器
基于slate构建文档编辑器 slate.js是一个完全可定制的框架,用于构建富文本编辑器,在这里我们使用slate.js构建专注于文档编辑的富文本编辑器. 描述 Github | Editor DE ...
- 使用webstorm+webpack构建简单入门级“HelloWorld”的应用&&引用jquery来实现alert
使用webstorm+webpack构建简单入门级"HelloWorld"的应用&&构建使用jquery来实现 1.首先你自己把webstorm安装完成. 请参考这 ...
- 构建简单的Maven工程,使用测试驱动的方式开发项目
构建简单的Maven工程很简单,这里写这篇随笔的原因是希望自己能记住几个小点. 一.安装Maven 1.下载maven:https://maven.apache.org/download.cgi 2. ...
- 【译】用boosting构建简单的目标分类器
用boosting构建简单的目标分类器 原文 boosting提供了一个简单的框架,用来构建鲁棒性的目标检测算法.这里提供了必要的函数来实现它:100% MATLAB实现,作为教学工具希望让它简单易得 ...
- 三、使用Maven构建简单的java项目
前边,我刚搭建了Maven环境,还有给大家推荐了学习资源,这个小节,我们来就来,,简单的玩玩maven. 1.所需工具: 1.Eclipse 2.apache-maven-3.3.9 3. ...
- Android 第三课 构建简单的用户界面
构建简单的用户界面 上一课下一课 该课程教你 创建线性布局 添加文本框 添加字符串资源 添加按钮 使输入框宽度充满整个屏幕 你也应该阅读 布局 Android的图形用户界面通过 View 和 View ...
- Ant—使用Ant构建简单Java项目(三)
博客<Ant-使用Ant构建简单Java项目(二)>我们简化了运行Test类中main方法须要运行的命令,本博客来介绍一下如何使build.xml文件和当中使用property标签定义的属 ...
- 学习笔记:Vue+Node+Mongodb 构建简单商城系统(二)
前面几个月工作有点忙,导致构建简单商城系统的计划搁置近三个月.现在终于有时间重新回过头来继续本计划.本篇主要记录自己在阿里云服务器上搭建node运行环境的整个过程,以及对其中遇到的一些问题的思考. 一 ...
随机推荐
- 停止调试 IIS 不退出
在VS主面板打开:工具->选项->调试->编辑继续 取消选中[启用"编辑并继续"] 就可以(不过这是针对所有的调试). 若只想对单个项目进行设置,可以选择自己 ...
- javaweb消息中间件——rabbitmq入门
概念:RabbitMQ是一款开源的消息中间件系统,由erlang开发,是AMQP的实现. 架构图大概如上. broker是消息队列的服务器,比如在linux上,我们安装的rabbitmq就是一个bro ...
- OpenCL 直方图
▶ 计算直方图,由原子计数和规约计算两部分组成 ● 最简单的版本,代码 // kernel.cl #pragma OPENCL EXTENSION cl_khr_local_int32_base_at ...
- 4 MySQL--表(增删改查)
1.表的介绍 表相当于文件,表中的一条记录就相当于文件的一行内容,不同的是,表中的一条记录有对应的标题,称为表的字段 id,name,qq,age称为字段,其余的,一行内容称为一条记录 2.创建表: ...
- 【转】跨DLLnew delete问题
转两篇文章来说这个问题的 链接1:https://blog.csdn.net/notebook2001a/article/details/6647850 链接2:https://blog.csdn.n ...
- 138. Copy List with Random Pointer (Graph, Map; DFS)
A linked list is given such that each node contains an additional random pointer which could point t ...
- EL表达式获取值栈数据
---------------------siwuxie095 EL 表达式获取值栈数据 1.导入 JSTL 相关包,下载链接: (1)http://tomcat.apache.org/taglibs ...
- set 续3
-------siwuxie095 set 技巧高级篇: 1.利用 set /a 进行赋值 在开启变量延迟情况下,要判断数组 S!n! 的值的情况, 不 ...
- 为什么数组没有实现Iterable接口,但可以使用foreach语句遍历
在Java中,对于数组为什么能够使用foreach语句一直感觉很困惑. 对于能够使用foreach语句进行遍历的对象,只有两种情况,其中一种是遍历对象必须实现Iterable接口,实现ierator( ...
- springboot中端点监管 endpoint actuator
1.pom文件 <?xml version="1.0" encoding="UTF-8"?> <project xmlns="htt ...