管道的作用就是将原始值进行转化处理,转换为所需要的值;


1. 新建sex-reform.pipe.ts文件

ng g pipe sex-reform

2. 编辑sex-reform.pipe.ts文件


import { Pipe, PipeTransform } form '@angular/core'; //引入PipeTransform是为了继承transform方法 @Pipe({ name: 'sexReform' }) //name属性值惯用小驼峰是写法, name的值为html中| 后面的名称 export class SexReformPipe implements PipeTransform {
transform(value: string, args?: any): string {
switch(value){
case 'male': return '男';
case 'female': return '女';
default: return '雌雄同体';
}
}
}

3. 使用demo组件中使用自定义管道

// demo.component.ts
export Class DemoComponent {
sexValue = 'male';
} // demo.component.html
<span>{{ sexValue | sexReform }}</span> // 浏览器输出
  • 同@Component({})和@NgModel({})一样,@Pipe({})代表这是一个管道,里面定义了一组元数据,用来告诉angular这个管道是如何工作的;

  • 每一个自定义管道都需要实现PipeTransform接口, transform方法用来对传入的值进行一系列处理,最后转化为需要的值后return即可;

  • transform()方法参数格式 - transform(value: string, args1: any, args2: any): value为传入的值(即为需要用此管道处理的值, | 前面的值); args 为传入的参数(?:代表可选);

  • html中使用管道格式 - {{ 数据 | 管道名 : 参数1 : 参数2 }}

最新文章

  1. Linux系统检查查看桌面环境
  2. git push如何至两个git仓库
  3. Java多态:upcast和downcast
  4. redis 初探
  5. 使用RBTool自动提交code review请求
  6. springmvc返回json字符串中文乱码问题
  7. php高精度计算问题
  8. Python使用正则表达式分割字符串
  9. JMeter非GUI模式下日志介绍
  10. java基础(4)继承和多态
  11. spring+springmvc+hibernate整合实例
  12. maven docker 插件集成的几个小坑
  13. H5静态资源本地化实践
  14. LeetCode 476 Number Complement 解题报告
  15. 连连看java版
  16. 调试程序时如何用syslog来打印信息
  17. 发送短信功能(C#)
  18. DataTables合并单元格(rowspan)的实现思路(多分组分类的情况)
  19. 细说 ASP.NET控制HTTP缓存[转]
  20. 一年25个里程碑!免疫疗法“战胜”癌症,靠的是实力(5篇Science、6篇Nature )--转载

热门文章

  1. docker运行原理与使用总结
  2. 分层图 单调决策性DP
  3. codeforces1076 A.B.C.D.E
  4. CodeForces 875 D High Cry
  5. Vue组件间通信方式
  6. Optional和Stream的map与flatMap
  7. FreeSql (一)入门
  8. java教程系列一:什么是Java语言?
  9. Redis是否安装
  10. 前端黑魔法:webworker动态化,无需JS文件创建worker