Angular-05:管道

  • ① 介绍
    • 1.1 基本用法
    • 1.2 管道参数
    • 1.3 链式管道
    • 1.4 纯管道
    • 1.5 非纯管道
  • ② 内置管道
  • ③自定义管道

① 介绍

  1. 管道:pipe 。在angular中处理组件模板的数据格式。
  2. 管道操作符 | ,连接模板表达式中左边输入数据和右边的管道。

1.1 基本用法

例:这里使用了内置管道 date 对日期的显示做了美化

<P>my birthday is {{birthday}}</P>   <!-- my birthday is Mon Feb 01 1993 00:00:00 GMT+0800 (中国标准时间) -->
<p>my birthday is {{ birthday | date }}</p>   <!-- my birthday is Feb 1, 1993 -->
birthday = new Date(1993,1,1);

1.2 管道参数

<P>my birthday is {{birthday | date:"y-MM-dd EEEE"}}</P>  <!-- my birthday is 1993-02-01 Monday -->
<P>my birthday is {{birthday | date:"y/MM/dd EEEE"}}</P>  <!-- my birthday is 1993/02/01 Monday -->
birthday = new Date(1993,1,1);

1.3 链式管道

一个模板表达式中可以连续使用多个管道进行不同的处理。

<P>my birthday is {{birthday | pipeName1 | pipeName2 | pipeName3}}</P>

模板表达式的值“birthday”,通过管道pipeName1处理后在传递给pipeName2处理,一直到最后一个管道处理完毕,就输出链式管道处理的最终结果。

1.4 纯管道

  1. angular管道有两种变化检测机制,分别对应两种类型:纯管道和非纯管道。
  2. 默认为纯管道。
  3. 只有在检测到输入值发生纯变更时才会调用纯管道的transform() 方法来实现数据转换,在将数据更新到页面上。
  4. 纯变更:基本数据类型输入值的变更或对象引用的更改。(对象的引用检测方式比遍历对象内部所有属性值要快的多,angular使用的是对象引用的监测策略)

1.5 非纯管道

  1. angular管道有两种变化检测机制,分别对应两种类型:纯管道和非纯管道。
  2. 使用非纯管道,angular组件在每个变化监测周期都会调用非纯管道,并执行管道的transform() 方法来更新页面数据。
  3. 通过在管道元数据里将pure属性值设置为false来定义非纯管道
@Pipe({name: 'test-pipe',pure: false
})

② 内置管道

内置管道列举

序号管道名类型说明
1Date纯管道日期管道,格式化日期
2Json非纯管道将输入数据对象经过JSON.stringify()方法转换后输出对象字符串
3UpperCase纯管道将文本所有小写字母转成大写字母
4LowerCase纯管道将文本所有大写字母转成小写字母
5Decimal纯管道数值处理
6Currency纯管道数值转成货币格式
7Percent纯管道数值转成百分比格式
8Slice非纯管道数组或字符串裁剪

③自定义管道

需求:

  1. 指定字符串不能超过规定长度,文字的长度超过规定的长度会被裁剪,并且显示…(省略号)
  2. 规定长度由管道参数决定
  3. substr() 语法: string.substr(start,length)。指定的是字符串的开始位置和长度

举例:

  1. 在页面上使用指令限制最多显示5个字,多余的截断并显示省略号。

定义管道:clipString

@Pipe({name: 'clipString'
})
export class ClipStringPipe implements PipeTransform {transform(value: string, limit: number): any {if (!value) return null;if (value.length > limit) {return value.substr(0, limit) + "...";}}}

组件模板中的应用

<p>{{'今天是星期六呢' | clipString:6}}</p>

需要在declarations中声明

@NgModule({imports: [CommonModule],declarations: [ClipStringPipe],exports: [SonComponent]
})
export class SonModule { }

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/124723.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

82.二分查找

目录 什么是二分查找 一、左闭右闭写法[left,right] 代码演示&#xff1a; 二、左闭右开写法[left,right] 代码演示&#xff1a; 今天进行了二分查找的学习。 什么是二分查找 二分查找&#xff08;Binary Search&#xff09;是一种常用的搜索算法&#xff0c;也被称为折…

VS Code2023安装教程(最新最详细教程)附网盘资源

目录 一.简介 二.安装步骤 三.VS Code 使用技巧 网盘资源见文末 一.简介 VS Code是一个由微软开发的跨平台的轻量级集成开发环境&#xff08;IDE&#xff09;&#xff0c;被广泛用于编写各种编程语言的代码。它支持多种编程语言&#xff0c;并且可以通过插件扩展功能。 以…

Undefined reference错误处理及Linux设置动态链接库so的默认搜索路径

文章目录 1 问题的提出2 问题的分析3 问题的解决3.1 Windows的VS修改配置属性3.2 Linux系统里添加搜索路径json在/usr/llib目录中libcryto.so在/usr/lib64文件夹中 Linux设置动态链接库so的默认搜索路径方法一&#xff1a;修改 ld.so.conf 文件方法二&#xff1a;修改环境变量方…

为什么 hooks 不能放在循环或者条件判断语句里?

React 官网介绍了 Hook 的这样一个限制&#xff1a; 不要在循环&#xff0c;条件或嵌套函数中调用 Hook&#xff0c; 确保总是在你的 React 函数的最顶层以及任何 return 之前调用他们。遵守这条规则&#xff0c;你就能确保 Hook 在每一次渲染中都按照同样的顺序被调用。这让 R…

matlab 布尔莎七参数坐标转换模型

目录 一、算法原理二、代码实现三、结果展示本文由CSDN点云侠原创,原文链接。爬虫自重,把自己当个人。 一、算法原理 算法原理与实现代码已在免费文章:布尔莎七参数坐标转换模型一文中给出,不想看付费文章直接跳转即可。 二、代码实现 clc; clear; close all; %% --

08 _ 栈:如何实现浏览器的前进和后退功能?

浏览器的前进、后退功能,我想你肯定很熟悉吧? 当你依次访问完一串页面a-b-c之后,点击浏览器的后退按钮,就可以查看之前浏览过的页面b和a。当你后退到页面a,点击前进按钮,就可以重新查看页面b和c。但是,如果你后退到页面b后,点击了新的页面d,那就无法再通过前进、后退…

Java中的锁:类型,比较,升级与降级

在Java中&#xff0c;锁是一种用于实现并发控制的重要工具。在多线程环境中&#xff0c;锁可以确保数据的一致性和完整性。Java提供了多种类型的锁&#xff0c;包括内置的synchronized关键字&#xff0c;ReentrantLock类以及更高级的并发工具&#xff0c;如StampedLock和ReadWr…

软考系统架构师知识点集锦十:计算机网络、数学与经济管理、知识产权与标准化

一、计算机网络 1.1、考情分析 2.1 TCP/IP协议簇 2.1.1常见协议及功能 网际层是整个TCP/IP体系结构的关键部分,其功能是使主机可以把分组发往任何网络并使分组独立地传向目标。 POP3: 110 端口&#xff0c;邮件收取SMTP: 25 端口&#xff0c;邮件发送FTP: 20数据端口/21控制…

Python异常处理

文章目录 异常格式异常类型自定义抛出异常类 异常格式 异常处理格式&#xff08;else和finally可省略&#xff09; try:path1&#xff08;可能发送异常的部分&#xff09; except:path2 else:path3 finally:path4如果没发送异常&#xff0c;执行path1, path3, path4 如果发送…

nextcloud+onlyoffice环境搭建(在线 or 离线)

1.安装 MySQL&#xff08;有MySQL就可以不装&#xff09; docker run -itd --name mysql8.0 -p 3306:3306 -e MYSQL_ROOT_PASSWORDroot --restartalways -e TZ"Asia/Shanghai" -v /home/docker/workspace/mysql:/var/lib/mysql mysql:latest --lower_case_table_na…

正点原子嵌入式linux驱动开发——外置RTC芯片PCF8563

上一章学习了STM32MP1内置RTC外设&#xff0c;了解了Linux系统下RTC驱动框架。一般的应用场合使用SOC内置的RTC就可以了&#xff0c;而且成本也低&#xff0c;但是在一些对于时间精度要求比较高的场合&#xff0c;SOC内置的RTC就不适用了。这个时候需要根据自己的应用要求选择合…

uni-app——如何阻止事件冒泡

引言 在开发移动应用程序时&#xff0c;我们经常需要处理用户交互事件。然而&#xff0c;有时候这些事件会冒泡&#xff0c;导致意外的行为和不良用户体验。在本文中&#xff0c;我们将探讨如何使用UniApp框架来阻止事件冒泡&#xff0c;并提供一些示例代码来帮助您理解如何实…

吉他、班卓琴和贝斯吉他降分器:Arobas Music Guitar 8.1.1

Arobas Music Guitar 是一款专业的吉他、班卓琴和贝斯吉他降分器。在熟练的手中&#xff0c;它不仅可以让您创作&#xff0c;还可以编辑、聆听和录制&#xff0c;以及导入和导出乐谱。如果有人感兴趣的话&#xff0c;录音是在八个轨道上进行的&#xff0c;你可以为每个轨道单独…

【go】两数求和

文章目录 题目代码解法2 代码仓库 题目 给定一个整数数组 nums 和一个整数目标值 target&#xff0c;请你在该数组中找出 和为目标值 target 的那 两个 整数&#xff0c;并返回它们的数组下标。 你可以假设每种输入只会对应一个答案。但是&#xff0c;数组中同一个元素在答案…

LeetCode 面试题 16.09. 运算

文章目录 一、题目二、C# 题解 一、题目 请实现整数数字的乘法、减法和除法运算&#xff0c;运算结果均为整数数字&#xff0c;程序中只允许使用加法运算符和逻辑运算符&#xff0c;允许程序中出现正负常数&#xff0c;不允许使用位运算。 你的实现应该支持如下操作&#xff1a…

android wifi和数据网络(以太网切换)出现的问题

场景1&#xff1a; 在实车上测试车机连接路由器的性能&#xff0c;车机连接着以太网&#xff0c;但是以太网没有网 然后车机通过WIFI连接一个路由器&#xff0c;电脑也连接路由器&#xff0c;突然发现车机通过路由器无法ping通路由器下的电脑&#xff0c;而且也ping不通路由器…

【数据挖掘 | 数据预处理】缺失值处理 重复值处理 文本处理 确定不来看看?

&#x1f935;‍♂️ 个人主页: AI_magician &#x1f4e1;主页地址&#xff1a; 作者简介&#xff1a;CSDN内容合伙人&#xff0c;全栈领域优质创作者。 &#x1f468;‍&#x1f4bb;景愿&#xff1a;旨在于能和更多的热爱计算机的伙伴一起成长&#xff01;&#xff01;&…

xxl-job-架构及原理

分布式调度框架 服务端 1、根据执行器创建任务&#xff0c; 2、底层通过netty发起调度。 客户端 1、注册到服务端成为执行器 2、注册任务类&#xff0c;任务类需要实现JobHandler这个接口的类 2、接受调度请求&#xff0c;找到对应的bean&#xff0c;并把bean放到线程池&…

模型对象CSS2DObject始终在画布的左上角(问题解决)

写了个简单案例模拟一下这个问题&#xff0c;看下图片 下面看下c2渲染器相关代码部分 this.css2DRenderer new CSS2DRenderer(); this.css2DRenderer.render(this.scene, this.camera); this.css2DRenderer.setSize(width, height); this.css2DRenderer.domElement.style.pos…

客户端与服务端实时通讯(轮询、websocket、SSE)

客户端与服务端实时通讯 背景 在某些项目中&#xff0c;某些数据需要展示最新的&#xff0c;实时的&#xff0c;这时候就需要和服务端进行长时间通讯 方案 对于数据实时获取&#xff0c;我们一般会有4种方案&#xff1a; 1.短轮询&#xff1a;使用浏览器的定时器发起http请…