接着第二部分,这部分介绍常见angular指令使用

1. 在父页面文件中添加组件(通过ng命令生成的component)

  1. <app-messages></app-messages>
  1. 其中messages,为组件名。

2. Angular 绑定数据

  • (1)数据文本绑定

定义数据几种方式:

  • public 共有(默认) 可以在类里外使用
  • protected 保护类型 只能在当前类和子类中使用
  • private 私有类型 只能在当期类使用

html文件中变量绑定:

  1. <h1>{{title}}</h1>
  • (2)绑定HTML

ts文件中定义文本:

  1. this.h="<h2>这是一个 h2 用[innerHTML]来解析</h2>"

  绑定方法:

  1. <div [innerHTML]="h"></div>

  h为ts中定义的变量,引用的时候将属性用[]包裹

3. 数据循环 *ngFor

1) ts文件中定义数组:

  1. export class xxxxxxxxxxxx implements OnInit {
  2.  
  3. arr = [{ name: 'poetries', age: 22 }, { name: 'jing' , age: 31}];
  4. constructor() { }
  5.  
  6. ngOnInit() {
  7. }
  8.  
  9. }

 2)   使用

     ngFor 普通循环

html文件中使用如下:

  1. <ul *ngIf="arr.length>0">
  2. <li *ngFor="let item of arr">{{item.name}}- {{item.age}}</li>
  3. </ul>

 循环的时候设置 key

     html文件中使用如下:

  1. <ul>
  2. <li *ngFor="let item of list;let i = index;"> <!-- 把索引index赋给i -->
  3. {{item}} --{{i}}
  4. </li>
  5. </ul>

 template 循环数据

  1. <ul>
  2. <li template="ngFor let item of list">
  3. {{item}}
  4. </li>
  5. </ul>

4. 条件判断 *ngIf

  1. <p *ngIf="list.length > 3">这是 ngIF 判断是否显示</p>
  2.  
  3. <p template="ngIf list.length > 3">这是 ngIF 判断是否显示</p>

  

5. *ngSwitch

  1. <ul [ngSwitch]="score">
  2. <li *ngSwitchCase="1">已支付</li>
  3. <li *ngSwitchCase="2">订单已经确认</li> <li *ngSwitchCase="3">已发货</li>
  4. <li *ngSwitchDefault>无效</li>
  5. </ul>

  

6. 执行事件 (click)=”getData()”

html:

  1. <button class="button" (click)="getData()"> 点击按钮触发事件
  2. </button>
  3. <button class="button" (click)="setData()"> 点击按钮设置数据
  4. </button>

ts:

  1. getData(){ /*自定义方法获取数据*/ //获取
  2. alert(this.msg);
  3. }
  4. setData(){
  5. //设置值
  6. this.msg='这是设置的值';
  7. }

  

7. 表单事件

html:

  1. <input
  2. type="text"
  3. (keyup)="keyUpFn($event)"/>
  4.  
  5. <input type="text" (keyup)="keyUpFn($event)"/>

ts:

  1. keyUpFn(e){
  2. console.log(e)
  3. }

  

8. 双向数据绑定

  1. <input [(ngModel)]="inputVal">

  注:需要引入FormsModule

9. [ngClass]、[ngStyle]

 [ngClass]:

示例1:

  1. <div [ngClass]="{'red': true, 'blue': false}">
  2. 这是一个 div
  3. </div>

ts:

  1. public flag=false; 

html:

  1. <div [ngClass]="{'red': flag, 'blue': !flag}">
  2. 这是一个 div
    </div>

示例2:

ts:

  1. public arr = [1, 3, 4, 5, 6];

html:

  1. <ul>
  2. <li *ngFor="let item of arr, let i = index"> <span [ngClass]="{'red': i==0}">{{item}}</span>
  3. </li> </ul>

[ngStyle]:

  1. <div [ngStyle]="{'background-color':'green'}">你好 ngStyle</div>

示例:

ts:

  1. public attr='red';

html:

  1. <div [ngStyle]="{'background-color':attr}">你好 ngStyle</div>

10. 管道

ts:

  1. public today=new Date();

html:

  1. <p>{{today | date:'yyyy-MM-dd HH:mm:ss' }}</p>

常用的管道(pipe)有:

  1. 大写:uppercase
  1. 小写:lowercase
  2. 日期格式:date:'yyyy-MM-dd HH:mm:ss'
  3. 小数位数:number:'1.2-4' 注:{最少整数位数}.{最少小数位数}-{最多小数位数}
  1. js对象序列化:
  1. <p>
  2. {{ { name: 'semlinker' } | json }}
  3. </p>

 slice:

  1. <p>{{ 'semlinker' | slice:0:3 }}</p>
  2. <!-- Output: sem -->

 管道链:

  1. <p>
  2. {{ 'semlinker' | slice:0:3 | uppercase }}
  3. </p>
  4.  
  5. <!-- Output: SEM -->

 自定义管道:

自定义管道的步骤:

  • 使用 @Pipe 装饰器定义 Pipe 的 metadata 信息,如 Pipe 的名称 - 即 name 属性
  • 实现 PipeTransform 接口中定义的 transform 方法

1)WelcomePipe 定义:

  1. import { Pipe, PipeTransform } from '@angular/core';
  2.  
  3. [@Pipe](/user/Pipe)({ name: 'welcome' })
  4.  
  5. export class WelcomePipe implements PipeTransform {
  6. transform(value: string): string {
  7. if(!value) return value;
  8. if(typeof value !== 'string') {
  9. throw new Error('Invalid pipe argument for WelcomePipe');
  10. }
  11. return "Welcome to " + value;
  12. }
  13. }

  2)WelcomePipe 使用

  1. <div>
  2. <p ngNonBindable>{{ 'semlinker' | welcome }}</p>
  3. <p>{{ 'semlinker' | welcome }}</p> <!-- Output: Welcome to semlinker -->
  4. </div>

  3)RepeatPipe 定义

  1. import {Pipe, PipeTransform} from '@angular/core';
  2.  
  3. [@Pipe](/user/Pipe)({name: 'repeat'})
  4. export class RepeatPipe implements PipeTransform {
  5. transform(value: any, times: number) {
  6. return value.repeat(times);
  7. }
  8. }

  4)RepeatPipe 使用

  1. <div>
  2. <p ngNonBindable>
  3. {{ 'lo' | repeat:3 }}
  4. </p>
  5. <p>
  6. {{ 'lo' | repeat:3 }}
  7. </p>
  8. <!-- Output: lololo -->
  9. </div>

  

  1.  

Angular7.1.4+Typescript3.1框架学习(三)的更多相关文章

  1. Angular7.1.4+Typescript3.1框架学习(一)

    起因:学习ionic4之前先学习下angular+ts 以win10为开发平台:当前最新版本为angular7;根据官网资料做如下总结: 1. angular安装 前提:Node.js 的 8.x 或 ...

  2. Angular7.1.4+Typescript3.1框架学习(二)

    接着第一部分,这篇文章就 Angular cli进行介绍总结: 1. ng g:列出当前命令 ng g 需在angular工程文件夹下执行: C:\Users\zb\angulardemo\heroe ...

  3. Struts2框架学习(三) 数据处理

    Struts2框架学习(三) 数据处理 Struts2框架框架使用OGNL语言和值栈技术实现数据的流转处理. 值栈就相当于一个容器,用来存放数据,而OGNL是一种快速查询数据的语言. 值栈:Value ...

  4. Android 学习笔记之AndBase框架学习(三) 使用封装好的函数完成Http请求..

    PS:踏踏实实走好每一步... 学习内容: 1.使用AndBase框架实现无参Http Get请求... 2.使用AndBase框架实现有参Http Post请求... 3.使用AndBase框架实现 ...

  5. python flask框架学习(三)——豆瓣微信小程序案例(二)整理封装block,模板的继承

    我们所要实现的效果: 点击电影的更多,跳转到更多的电影页面:点击电视剧的更多,跳转到更多的电视剧页面. 三个页面的风格相同,可以设置一个模板,三个页面都继承这个模板 1.在指定模板之前,把css放在一 ...

  6. WebGL——osg框架学习三

    今天继续来Draw绘制的osg模块的学习,昨天我们学习的是StateBin渲染状态树节点类,今天我们来继续学习下一个Draw的基础类DrawableEntity渲染对象实体类.这个类和Drawable ...

  7. django 基础框架学习 (三)

    Django框架基础-03数据库新增数据    1.save⽅法        >>> from datetime import date        >>> f ...

  8. Struts2框架学习(三)——配置详解

    一.struts.xml配置 <?xml version="1.0" encoding="UTF-8"?> <!DOCTYPE struts ...

  9. Hibernate框架学习(三)——实体规则、对象状态、一级缓存

    一.Hibernate中的实体规则 1.实体类创建的注意事项 1)持久化类提供无参数构造,因为在Hibernate的底层需要使用反射生成类的实例. 2)成员变量私有,提供公有的get和set方法,需提 ...

随机推荐

  1. 【DOM练习】淘宝购物车

    HTML: <!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <tit ...

  2. 结合API Gateway和Lambda实现登录时的重定向和表单提交请求(Python3实现)

    1. 创建Lambda函数,代码如下: from urllib import parse def lambda_handler(event, context): body = event['body' ...

  3. 遍历table明细是否为空

    //循环遍历 <tbody id="linedata2">,获取每行值对比 $("#linedata2 tr").each(function(i,n ...

  4. 操作redis

    数据库分为: 1)传统的关系型数据库 mysql.oracle.sql server.sqllie.db2 id name passwd cratetime stu 特点: a 数据存在磁盘上 b 使 ...

  5. class的真相

    Java中Class类及用法 Java程序在运行时,Java运行时系统一直对所有的对象进行所谓的运行时类型标识,即所谓的RTTI.这项信息纪录了每个对象所属的类.虚拟机通常使用运行时类型信息选准正确方 ...

  6. hiberate 映射关系 详解

    在我们平时所学的关系型数据库中,我们会大量处理表与表之间的关系,如果表比较多的话处理起来就比较繁琐了,但是hibernate给我们提供了很大的便利,这些便利让我们处理起来方便.我们所讲的源码地址:ht ...

  7. 物理层PHY 和 网络层MAC

    PHY模块简介 物理层位于OSI最底层,物理层协议定义电气信号.线的状态.时钟要求.数据编码和数据传输用的连接器. 物理层的器件称为PHY. 上图里的灰色方框图里的就是PHY芯片内部模块图. MAC器 ...

  8. Oracle错误——ORA-39002:操作无效、ORA-39070:无法打开日志文件、ORA-06512:在“SYS.UTL_FILE”,line

    错误 在使用数据泵impdp导入文件时,出现错误,无法导入数据 Next 问题原因 初步猜测,应该是Oracle用户权限出现问题,是对Directory目录无操作权限所致,经过一番修改和测试,发现使用 ...

  9. Xgboost GPU 加速

    import xgboost as xgb import numpy as np from sklearn.datasets import fetch_covtype from sklearn.mod ...

  10. 【使用指南】ComponentOne Enterprise .NET开发控件集

    为方便广大 .NET开发人员更好的使用 ComponentOne Enterprise .NET开发控件集,葡萄城专门推出了 ComponentOne Enterprise 使用指南,该指南详细地介绍 ...