iis服务器助手广告广告
返回顶部
首页 > 资讯 > 前端开发 > 其他 >一文聊聊Angular中的管道(PIPE)
  • 488
分享到

一文聊聊Angular中的管道(PIPE)

管道Angular 2023-05-14 22:05:34 488人浏览 独家记忆
摘要

在我们设置好管道之后,浏览器中的时间已经发生了变化了其他管道angular还提供了其他管道,比如说改变人名币格式的管道(currency):Angular - CurrencyPipehttps://angular.cn/api/commo

在我们设置好管道之后,浏览器中的时间已经发生了变化了

3.png

其他管道

angular还提供了其他管道,比如说改变人名币格式的管道(currency):

4.png

Angular - CurrencyPipe

https://angular.cn/api/common/CurrencyPipe

还有将字符串转化为大写的管道(uppercase):

<div>{{'ASDasd' | uppercase }}</div>

5.png

Angular - UpperCasePipe

Https://angular.cn/api/common/UpperCasePipe

自定义管道


在上面我们介绍了几种内置管道,那万一要是内置管道都不能满足我们开发的需求,那么 Angular 还给我们提供了自定义管道,你可以自己去定一个管道,定义要去如何转化输入。

我们可以通过 Angular 提供给我们的命令行去快捷生成一个管道:

ng g p pipes/pipe-name

这里我创建了一个名为 test 的管道

6.png

在你运行上面的指令之后,就会在 src 下为你创建一个 pipes 的文件夹,里面保存着你的自定义管道

7.png

然后再 app 中 Angular 会自动帮你引入这些管道,这样你就能够在全局每个地方使用自定义的管道。

8.png

接着看到在 pipes 文件夹下的管道,管道本质上就是个类,这里使用装饰器来为它取了个 tests 的名字。

在这个类里面我们需要去实现 PipeTransfrom 这个接口,也就是需要有 transfORM 这个方法,在这个方法中,第一个参数就是要放入管道的输入,第二个数据是我们向管道传递的参数,管道中把它放入了一个数组里面。

这个 transform 方法返回什么,我们的页面拿到的就是什么数据,我们先来做一个测试

  transform(value: unknown, ...args: unknown[]): unknown {
    return 'tests';
  }
  ...
  <div>{{'ASDasd' | tests }}</div>

返回一个固定的字符串,并且在页面中去使用它

9.png

可以看到返回的结果变成了 tests 字符串,这样我们就可以确定这个方法的返回值就是最终的输出。

接下来我们实现一个简单的字符串超出截取的管道:

  transform(value: string, ...args: number[]): string {
    let defaultLength = 10;
    if((args[0] || defaultLength )< value.length){
      return value.substr(0,args[0] || defaultLength)+'...'
    }else{
      return value
    }
  }
  ...
  <div>{{'sssssssssssssssssssssssssssssss' | tests: 30 }}</div>

这样就能够对字符串进行一个截取并且在尾部添加 ...

10.png

总结


本文我们学习了 Angular 中管道的使用,简单的来说管道就是一个方法,可以将你的输入转化为特定的你需要的输出格式,Angular提供给了我们许多的内置管道,当内置管道不满足你的要求的时候,你还可以通过自定义管道来更加灵活的自定义输出格式

以上就是一文聊聊Angular中的管道(PIPE)的详细内容,更多请关注编程网其它相关文章!

--结束END--

本文标题: 一文聊聊Angular中的管道(PIPE)

本文链接: https://www.lsjlt.com/news/206535.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • 一文聊聊Angular中的管道(PIPE)
    在我们设置好管道之后,浏览器中的时间已经发生了变化了其他管道Angular还提供了其他管道,比如说改变人名币格式的管道(currency):Angular - CurrencyPipehttps://angular.cn/api/commo...
    99+
    2023-05-14
    管道 Angular
  • 一文聊聊Angular中的依赖注入
    译者添加:举个例子 -- 当 classA 使用 classB 的某些功能时,则表示 classA 具有 classB 的依赖。在使用 classA 之前,我们需要创建 classB。推荐文章依赖注入是什么?如何使用它?我们都知道在 Ang...
    99+
    2023-05-14
    前端 JavaScript Angular.js
  • 深入聊一聊Angular开发的内容
    目录前言组件 Component路由 Router管道 Pipeline指令 Directive服务 Service总结前言 阅读本文,是在你了解 Angular 基本知识的前提下,...
    99+
    2024-04-02
  • 一文聊聊Node中的stream(流)
    流是用于在 Node.js 中处理流数据,也就是连续字节的抽象接口。 流有 4 种基本类型,本篇文章主要介绍其中两种 —— 可读流和可写流。可读的(Readable)我们可以通过 fs.createReadStream() 创建一个可读流 ...
    99+
    2023-05-14
    stream node nodejs​
  • 一文聊聊node中的path模块
    path 模块是 nodejs 中用于处理文件/目录路径的一个内置模块,可以看作是一个工具箱,提供诸多方法供我们使用,当然都是和路径处理有关的。同时在前端开发中 path 模块出现的频率也是比较高的,比如配置 webpack 的时候等。本文...
    99+
    2023-05-14
    path模块 Node.js
  • 一文聊聊Node中的可读流
    本篇文章带大家解读一下Node.js流源码,深入了解下Node可读流,看看其基本原理、使用方法与工作机制,希望对大家有所帮助!1. 基本概念1.1. 流的历史演变流不是 Nodejs 特有的概念。 它们是几十年前在 Unix 操作系统中引入...
    99+
    2023-05-14
    可读流 node
  • 一文聊聊Node中的net模块
    而客户端和服务端的传输流如下如果角色变成发送者和接受者的时候,传输流如下图:可以看出来传输的过程中,从发送端开始,没经过一层协议都会加上所需要的首部信息.层层把关,层层加码. 然后到了接收端的时候, 就反而行之, 每经过一层都剥去对应的首部...
    99+
    2023-05-14
    net模块 node Node.js
  • 一文聊聊Node.js中的cluster(集群)
    日常工作中,对 Node.js 的使用都比较粗浅,趁未羊之际,来学点稍微高级的,那就先从 cluster 开始吧。尼古拉斯张三说过,“带着问题去学习是一个比较好的方法”,所以我们也来试一试。当初使用 cluster 时,一直好奇它是怎么做到...
    99+
    2023-05-14
    cluster Node.js
  • 一文聊聊vue3中的ref、toRef、toRefs
    (学习视频分享:vuejs入门教程、编程基础视频)以上就是一文聊聊vue3中的ref、toRef、toRefs的详细内容,更多请关注编程网其它相关文章!...
    99+
    2023-05-14
    Vue
  • 一文聊聊Vue中的KeepAlive组件
    看下面的图更加直观,图片来源一篇讲keepAlive 缓存优化的文章4、如何添加到 vue devtools 组件树上sharedContext.activate = (vnode, container, anchor) => { ...
    99+
    2022-11-22
    前端 Vue.js 前端框架
  • Angular管道PIPE的介绍与使用方法
    前言 PIPE,翻译为管道。Angular 管道是编写可以在HTML组件中声明的显示值转换的方法。Angular 管道之前在 AngularJS 中被称为过滤器,从 Angular ...
    99+
    2024-04-02
  • 一文聊聊Javascript中的执行上下文
    本篇文章带大家聊聊Javascript中的执行上下文,分享一个思考题,通过对思考题的分析,想必会对执行上下文有更加深入的理解。在前面的几篇文章中,我们深入了解了关于执行上下文的三个重要成员:变量对象、作用域链和 this ,本篇文章是前四篇...
    99+
    2023-05-14
    执行上下文 javascript
  • 一文聊聊Node中的内存控制
    3.内存指标会存在一些认为会回收但是却没有被回收的对象,会导致内存占用无限增长。一旦增长达到v8的内存限制,将会得到内存溢出错误,进而导致进程退出。3.1 查看内存使用情况process.memoryUsage()可以查看内存使用情况。除此...
    99+
    2023-05-14
    前端 Node.js 后端
  • 一文聊聊Vue中的全局守卫
    Vue中怎么进行全局守卫?下面本篇文章带大家聊聊Vue中的全局守卫,希望对大家有所帮助!前言:项目中大多数都是通过路由来进行跳转的,但是普遍的都会进行登陆验证后才能进入下一页面,这时候就需要守卫了,本博文主要讲解vue中的全局守卫 。全局守...
    99+
    2023-05-14
    全局守卫 Vue
  • 一文聊聊Node包管理发展的五个阶段
    从2009年 Node 诞生至今,Node 生态发展繁荣,围绕 Node 生态衍生出的 Node 包管理器百花齐放,先后出现了 npm、kpm、pnpm、yarn、cnpm 等等。实际上 Node 包管理器发展主要分5个阶段,下面我们一起看...
    99+
    2023-05-14
    包管理 node
  • 一文聊聊vue中的指令和插值
    data():存放页面中显示数据的地方<!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title...
    99+
    2022-11-22
    Vue vue.js vue3
  • 一文聊聊golang中的整数相除问题
    Go是一种非常流行的编程语言,适用于编写高度可伸缩的网络服务器和分布式系统。在这篇文章中,我们将讨论Go语言中的整数相除问题。在Go中,整数相除的结果是一个整数,这意味着如果两个整数相除的结果是一个小数,则小数部分将被截断,并且只保留整数部...
    99+
    2023-05-14
  • 一文聊聊gitlab的3种权限
    Gitlab是一种开源版本控制系统,具有强大的管理和控制功能。Gitlab的权限设置是它的重要特性之一,它可以确保每个用户在使用Gitlab进行版本控制时都能得到适当的权限。Gitlab权限可分为三个不同的层次:系统层、组层和项目层。系统层...
    99+
    2023-10-22
  • 一文聊聊node文件的读写操作
    本篇文章带大家聊聊fs文件系统模块,介绍一下node中的文件读取写入操作,希望对大家有所帮助!fs文件系统模块什么是fs文件系统模块fs模块是node.js官方提供的、操作文件的模块。通过fs模块可以实现对文件的读取以及写入操作。【相关教程...
    99+
    2023-05-14
    node Node.js
  • 一文带你聊聊Nodejs中读写文件的操作
    操作文件是服务端一个基础的功能,也是做后端开发的必备能力之一。操作文件主要包括读和写。而这些功能 Nodejs 都已经提供了对应的方法。只要调用就行了。创建文件夹同步方法const fs = require('fs') fs...
    99+
    2022-11-22
    nodejs node
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作