Filter:过滤器,用于在view中呈现数据时显示为另一种格式;过滤器的本质是一个函数,接收原始数据转换为新的格式进行输出:

function(oldVal){ ... return newVal }

使用过滤器:{{ e.salary  | 过滤器名 }}

Angular2.x中,过滤器更名为  “管道(Pipe)”

自定义管道的步骤:

1.创建管道class,实现转换功能

@Pipe({ name:'sex' })

export class SexPipe{

transform(val){ return ....}

}

2.在模块中注册管道

//app.module.ts

declarations:[ SexPipe ]

3.在模板视图中使用管道

{{e.empSex | sex}}

<p [title]="empSex | sex"></p>

说明:管道的transform方法除了val还可以接受其他参数,

调用管道时用冒号为这些参数赋值,例如:{{e.empSex | sex:'en' }}

创建管道对象的简便工具: ng  g  pipe  管道名

Vue.js中没有预定义管道;Angular提供了几个预定义管道:

1.lowercase:转换为小写

{{ename | lowercase }}

2.uppercase:转换为大写

{{ename | uppercase }}

3.titlecase:转换为首字母大写

{{ename | titlecase }}

4.slice:只显示字符串的一部分

{{ename | slice : 0 : 3 }}

5.json:将JS对象序列化为JSON字符串

{{obj | json }}

6.number:把数字转换为具有指定整数位和小数位的字符串

{{num | number }}

{{num | number:'4.1 -4 '}}

7.currency:把数字转换为货币格式字符串:货币符号+三位一逗号+两位小数位

{{num | currency }}

{{num | currency:'¥' }}

8.date:把数字转换为日期字符串

{{num | date:'yyyy-MM-dd HH:mm:ss' }}

2.创建对象的两种方式

方式一:手工创建式  --------自己创建:let  c2 = new  Car()

 方式二:依赖注入   ---------无需自己new,只需要声明依赖;

服务提供者就会创建被依赖的对象,注入给服务需要者。

3.Angular核心概念之六  -----服务和依赖注入-----抽象&重点!

Service:服务,Aangular认为:组件是与用户交互的一种对象,其中的内容都应该

与用户操作有关系的;而与用户操作无关的内容都应该剥离出去,放在“服务对象”中,

为组件服务;例如日志记录、计时统计、数据服务器访问.....

创建服务对象的步骤:

1.创建服务对象并指定服务提供者

@Injectable({ providedIn:'root' })

export class LogService{    }

 2.在组件中声明依赖,服务提供者就会自动注入进来,组件直接使用服务对象即可。

export class XxComponent{

constructor(log:LogService){

//此处的log变量就会被注入为LogService实例

}

}

面试题:前端有哪些异步请求工具?各自的利弊?

1.原生的XHR

2.jQuery.ajax()

3.Axios

4.Angular     HttpClient

5.Fetch

使用服务对象时(依赖注入)常见错误:

ERROR NullInjectorError: StaticInjectorError(AppModule)[Myc03Component -> LogService]:
StaticInjectorError(Platform: core)[Myc03Component -> LogService]:
NullInjectorError: No provider for LogService!

指定的服务对象没有服务提供者;

解决方案:

1.保证创建服务对象时指定providedIn:'root'

2.组件声明依赖时服务对象不能写错

4.使用Angular官方提供的服务对象-----HttpClient  Service

HttpClient服务对象用于指定的URL发起异步请求,使用步骤:

1.在主模块中导入HttpClient服务所在的模块

//app.module.ts

imports:[ BrowserModule,FormsModule,HttpClientModule ]

2.在需要使用异步请求的组件中声明依赖于HttpClient服务对象,就可以使用该对象发起

异步请求了。

http = null

constructor( http:HttpClient ){

this.http =http

}

Angular核心概念之五---过滤器的更多相关文章

  1. Angular核心概念

    一.集成开发环境@angular/cli IE8之后才有debugger工具 2009,nodejs发布,前端Big Bang 1.1 基于NodeJS的工具链 打包工具 grunt 对js代码做合并 ...

  2. Angular 核心概念

    module(模块) 作用 通过模块对页面进行业务上的划分,根据不同的功能划分不同的模块. 将重复使用的指令或者过滤器之类的代码做成模块,方便复用 注意必须指定第二个参数,否则变成找到已经定义的模块 ...

  3. Angular 核心概念2

    自定义指令 指令增强了 HTML,提供额外的功能 内置的指令基本上已经可以满足我们的绝大多数需要了 少数情况下我们有一些特殊的需要,可以通过自定义指令的方式实现 普通指令 语法 <div hel ...

  4. 2 Angular 2 的核心概念

    一.组件(Components): 组件是构成 Angular 应用的基础和核心,它是一个模板的控制类,用于处理应用和逻辑页面的视图部分.组件知道如何渲染自己及配置依赖注入,并通过一些由属性和方法组成 ...

  5. Angularjs -- 核心概念

     angularjs旨在减轻使用AJAX开发应用程序的复杂度,使得程序的创建.測试.扩展和维护变得easy.以下是angularjs中的一些核心概念. 1. client模板      多页面的应用通 ...

  6. 第214天:Angular 基础概念

    一.Angular 简介 1. 什么是 AngularJS - 一款非常优秀的前端高级 JS 框架 - 最早由 Misko Hevery 等人创建 - 2009 年被 Google 公式收购,用于其多 ...

  7. Spring 核心概念

    Spring 核心概念 引言 本文主要介绍 Spring 源码中使用到的一些核心类 1. BeanDefinition BeanDefinition表示Bean定义,BeanDefinition 中存 ...

  8. 领域驱动设计(DDD)部分核心概念的个人理解

    领域驱动设计(DDD)是一种基于模型驱动的软件设计方式.它以领域为核心,分析领域中的问题,通过建立一个领域模型来有效的解决领域中的核心的复杂问题.Eric Ivans为领域驱动设计提出了大量的最佳实践 ...

  9. Javascript本质第一篇:核心概念

    很多人在使用Javascript之前都至少使用过C++.C#或Java,面向对象的编程思想已经根深蒂固,恰好Javascript在语法上借鉴了Java,虽然方便了Javascript的入门,但要深入理 ...

随机推荐

  1. 结构体 偏移量 (size_t)&(((s *)0)->m) , list相关

    在Windows SDK 的stddef.h 中 #define offsetof(s,m) (size_t)&(((s *)0)->m) 应用例如 #define list_conta ...

  2. java中的daemon thread

    java中的daemon thread java中有两种类型的thread,user threads 和 daemon threads. User threads是高优先级的thread,JVM将会等 ...

  3. 最大比例 公约数复用 【蓝桥真题】 (c++)

    最大比例 X星球的某个大奖赛设了M级奖励.每个级别的奖金是一个正整数.并且,相邻的两个级别间的比例是个固定值.也就是说:所有级别的奖金数构成了一个等比数列.比如:16,24,36,54其等比值为:3/ ...

  4. JSP、ASP、PHP Web应用程序怎么这么多P!

    之前我们说完了计算机网络应用程序的两种结构:C/S,B/S(传送门)今天我们详细说一说B/S开发中的这么多P是干什么的. 1.什么是Web应用程序 一个Web应用程序是由完成特定任务的各种Web组件( ...

  5. shell之路 shell核心语法【第三篇】运算

    Bash 支持很多运算符,包括算数运算符.关系运算符.布尔运算符.字符串运算符和文件测试运算符. 原生bash不支持简单的数学运算,默认都是字符串操作,但是可以通过其他命令来实现 算数运算 expr. ...

  6. MySQL 入门(2):索引

    摘要 在这篇文章中,我会先介绍一下什么是索引,索引有什么作用. 之后会介绍一下索引的数据结构是什么样的,有什么优点,又会带来什么样的问题. 在分析完数据结构后,我们可以根据这个数据结构,研究索引的用法 ...

  7. Linux下swap到底有没有必要使用

    周五看到QQ群里在讨论Linux主机上到底需不需要开启swap空间,而且目前公有云主机默认都是把swap关了的,很多公司也是没有开启swap,那到底需不需要开启呢? 我之前在看<鸟哥的Linux ...

  8. Tunnel Warfare 线段树 区间合并|最大最小值

    B - Tunnel WarfareHDU - 1540 这个有两种方法,一个是区间和并,这个我个人感觉异常恶心 第二种方法就是找最大最小值 kuangbin——线段树专题 H - Tunnel Wa ...

  9. 流媒体与实时计算,Netflix公司Druid应用实践

    Netflix(Nasdaq NFLX),也就是网飞公司,成立于1997年,是一家在线影片[租赁]提供商,主要提供Netflix超大数量的[DVD]并免费递送,总部位于美国加利福尼亚州洛斯盖图.199 ...

  10. QtCreator MSVC 搭建 Debugger

    QtCreatorForWindows搭建Debugger QtCreator for windows选择mingw或者msvc: qt-opensource-windows-x86-msvc2015 ...