1、通过文本框输入,向数组添加数据

<!-- 通过文本框输入,向数组添加数据 push -->

<input type="text" name="111" [(ngModel)]="username">
<button (click)="addData()">增加</button>
<ul>
<li *ngFor='let item of list'>
{{item}}
</li>
</ul> export class TodolistComponent implements OnInit {
public username:any='';
public list=[]; addData(){
this.list.push(this.username);/*向数组推数据*/
}

}

2、删除数组的数据

<!-- 删除数组的数据 splice -->

<input type="text" name="111" [(ngModel)]="username">
<button (click)="addData()">增加</button>
<ul>
<li *ngFor='let item of list ;let i=index;'>
{{item}} ------ <button (click)='deleteData(i)'>删除</button>
</li>
</ul> export class TodolistComponent implements OnInit {
public username:any='';
public list=[]; addData(){
this.list.push(this.username); /*向数组推数据*/
}
deleteData(aaa){ /* 将索引值i赋给aaa */
this.list.splice(aaa,1); /*删除数组的数据*/
}

}

3、按下键盘回车“Enter”向数组添加数据

具体参照angularcli第四篇(执行事件)

  • 实现的功能:在input框中输入数据,前面是通过按下按钮数据添加到数组中,现在要改成按下回车键:

  • 步骤:

(1)给input增加鼠标监听事件:

通过keyup / keydown监听鼠标是否按下input框(鼠标监听事件keyup / keydown,鼠标按下、抬起增加触发事件)。

(2)怎么知道我们在键盘上按的是哪个键?

通过事件对象 $event,来获取鼠标所监听的对象(即:input)在键盘上按下哪个键。

代码:
<input type="text" [(ngModel)]="username" (keyup)="addData($event)">
<ul>
<li *ngFor='let item of list;let i=index;'>
{{item}} ------ <button (click)='deleteData(i)'>删除</button>
</li>
</ul> export class TodolistComponent implements OnInit {
  public username:any='';
  public list=[];
  addData(e){
/* console.log(e); */
  if (e.keyCode==13) {
  this.list.push(this.username) /* 在input框中输入数据,按下回车键,数据添加到数组中 */
       this.username=''; /* 输入数值回车之后,清空输入框 */
  }
 }

deleteData(aaa){
  this.list.splice(aaa,1); /*删除数组的数据*/
 }
}

3、将数组列表分成“已完成”和“未完成”,通过按钮来转换

  • 实现的功能:点击 “改变状态” 切换数据的状态、点击 “删除” 就删除该条数据。

  • 思路:为每一条数据添加一个状态,值为 “1” 或 “2” ;  再加一个按钮,这个按钮的作用就是改变状态的值;  通过条件判断,状态为1时显示“正在进行”,状态为2时显示“已完成”。
  • 步骤:

(1)定义一个对象,对象里包括数据内容、状态     var obj={ username:this.username , status:1 }

(2)向数组中推入这个对象,将  this.list.push(this.username)  改成   this.list.push(obj); 

(3)HTML中: 将  {{item}}  改成  {{item.username}} 

(4)添加一个button,点击事件改变 status 的值       changeData(bbb) {   this.list[bbb].status=2;  }

(5)在 <li> 标签中添加条件判断语句   *ngIf='status==1'  或者  [hidden]='status==2'  来控制显示和隐藏

注:一个元素上边没法绑定多个模板, <li> 标签上已经绑定了*ngFor,所有这里用 [hidden]。

<label>输入框:</label>
<input type="text" [(ngModel)]="username" (keyup)="addData($event)"> <h2>正在进行:</h2>
<ul>
<li *ngFor='let item of list ;let i=index;' [hidden]='item.status==2'> <!-- status=2时隐藏 -->
<button (click)='changeData(i)'>改变状态</button>
{{item.username}} ----- {{item.status}}
<!-- 获取对象中的username和status -->
<button (click)='deleteData(i)'>删除</button>
</li>
</ul> <h2>已经完成:</h2>
<ul>
<li *ngFor='let item of list ;let i=index;' [hidden]='item.status==1'> <!-- status=1时隐藏 -->
<button (click)='changeData(i)'>改变状态</button>
{{item.username}}-----{{item.status}}
<button (click)='deleteData(i)'>删除</button>
</li>
</ul>
typescript代码:
export class TodolistComponent implements OnInit {
public username:any='';
public list=[]; constructor() { } ngOnInit() {
} addData(e){ var obj={ /* 定义一个对象 */
username:this.username,
status:1
}

if (e.keyCode==13) {
this.list.push(obj); /* 向数组中添加对象obj */
this.username=''; /* 清空输入框 */
}
}
changeData(bbb){ /*改变状态*/
this.list[bbb].status=2;
}
deleteData(aaa){
this.list.splice(aaa,1); /*删除数组的数据*/
}

angularcli 第六篇(todolist 列表)的更多相关文章

  1. 解剖SQLSERVER 第十六篇 OrcaMDF RawDatabase --MDF文件的瑞士军刀(译)

    解剖SQLSERVER 第十六篇 OrcaMDF RawDatabase --MDF文件的瑞士军刀(译) http://improve.dk/orcamdf-rawdatabase-a-swiss-a ...

  2. 解剖SQLSERVER 第六篇 对OrcaMDF的系统测试里避免regressions(译)

    解剖SQLSERVER 第六篇  对OrcaMDF的系统测试里避免regressions (译) http://improve.dk/avoiding-regressions-in-orcamdf-b ...

  3. 第六篇 Replication:合并复制-发布

    本篇文章是SQL Server Replication系列的第六篇,详细内容请参考原文. 合并复制,类似于事务复制,包括一个发布服务器,一个分发服务器和一个或多个订阅服务器.每一个发布服务器上可以定义 ...

  4. 第六篇 Integration Services:初级工作流管理

    本篇文章是Integration Services系列的第六篇,详细内容请参考原文. 简介在前几篇文章中,我们关注使用增量加载方式加载数据.在本篇文章,我们将关注使用优先约束管理SSIS控制流中的工作 ...

  5. Python之路【第六篇】:socket

    Python之路[第六篇]:socket   Socket socket通常也称作"套接字",用于描述IP地址和端口,是一个通信链的句柄,应用程序通常通过"套接字&quo ...

  6. 【Python之旅】第六篇(七):开发简易主机批量管理工具

    [Python之旅]第六篇(七):开发简易主机批量管理工具 python 软件开发 Paramiko模块 批量主机管理 摘要: 通过前面对Paramiko模块的学习与使用,以及Python中多线程与多 ...

  7. ElasticSearch入门 第六篇:复合数据类型——数组,对象和嵌套

    这是ElasticSearch 2.4 版本系列的第六篇: ElasticSearch入门 第一篇:Windows下安装ElasticSearch ElasticSearch入门 第二篇:集群配置 E ...

  8. 【译】第六篇 Replication:合并复制-发布

    本篇文章是SQL Server Replication系列的第六篇,详细内容请参考原文. 合并复制,类似于事务复制,包括一个发布服务器,一个分发服务器和一个或多个订阅服务器.每一个发布服务器上可以定义 ...

  9. 【译】第六篇 Integration Services:初级工作流管理

    本篇文章是Integration Services系列的第六篇,详细内容请参考原文. 简介在前几篇文章中,我们关注使用增量加载方式加载数据.在本篇文章,我们将关注使用优先约束管理SSIS控制流中的工作 ...

随机推荐

  1. Data Flow ORB-SLAM for Real-Time Performance on Embedded GPU Boards

    张宁 Data Flow ORB-SLAM for Real-Time Performance on Embedded GPU Boards 数据流ORB-SLAM可在嵌入式GPU板上实现实时性能链接 ...

  2. json 格式化处理工具

    json 格式化处理工具 用于JSON的快速命令行处理工具,简单无依赖. 我这边列举一些最常用的: 调试 http 请求时打印格式化后的数据 格式化本地或或流中的数据 获取 json 的键值或进行执行 ...

  3. [转帖]rename(Perl语言版本) 详解

    rename(Perl语言版本) 详解 2019-03-19 22:51:23 wayne17 阅读数 464更多 分类专栏: Ubuntu之路   版权声明:本文为博主原创文章,遵循CC 4.0 B ...

  4. c++11多线程记录3: 数据争用和Mutex的使用

    https://www.youtube.com/watch?v=3ZxZPeXPaM4 学习视频 数据争用 简单来说就是存在多个线程同时对某个共同的对象进行读写(至少有一个线程在做写操作),造成读取这 ...

  5. 「UR#5」怎样更有力气

    「UR#5」怎样更有力气 解题思路 考虑没有限制的情况,一定是把操作离线下来,按照边权从小到达做.可以发现,如果没有限制,完全图是多余的,直接拿树边进行合并就可以了.我们要做这么一件事情,把每个点属于 ...

  6. Luogu2481 SDOI2010 代码拍卖会 DP、组合

    传送门 神仙DP 注意到\(N \leq 10^{18}\),不能够直接数位DP,于是考虑形成的\(N\)位数的性质. 因为低位一定不会比高位小,所以所有满足条件的\(N\)位数一定是不超过\(9\) ...

  7. CapsLock Enhancement via AutoHotKey

    上次写了一篇博文,讲如何通过AutoHotKey改造CaspLock,使其成为一个方便的编辑按键,并特意给出了设计的思路方便参考. 见地址:http://www.cnblogs.com/Vonng/p ...

  8. 软件测试人员必备的Python知识图库

    UI自动化测试(Python+Selenium等) 接口测试(Python requests等) 性能测试(Python Locust等) 安全性测试(Python Scapy等) 兼容性测试(Pyt ...

  9. string.Compare()方法

    判断字符串中是否包含一个值 返回一个值,该值指示指定的 String 对象是否出现在此字符串中. String a = "abcd"; if(source.a("a&qu ...

  10. Hadoop—MapReduce计算气象温度

    Hadoop-MapReduce计算气象温度 1 运行环境说明 1.1 硬软件环境 主机操作系统:Mac OS 64 bit ,8G内存 虚拟软件:Parallers Desktop12 虚拟机操作系 ...