我的编程空间,编程开发者的网络收藏夹
学习永远不晚

ES6管道运算符怎么用

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

ES6管道运算符怎么用

这篇文章主要介绍“ES6管道运算符怎么用”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“ES6管道运算符怎么用”文章能帮助大家解决问题。

JS中得管道运算符。

Unix 操作系统有一个管道机制(pipeline),可以把前一个操作的值传给后一个操作。这个机制非常有用,使得简单的操作可以组合成为复杂的操作。许多语言都有管道的实现,现在有一个提案,让 JavaScript 也拥有管道机制。

JavaScript 的管道是一个运算符,写作|>。它的左边是一个表达式,右边是一个函数。管道运算符把左边表达式的值,传入右边的函数进行求值。

x |> f

// 等同于

f(x)

管道运算符最大的好处,就是可以把嵌套的函数,写成从左到右的链式表达式。

function doubleSay (str) {

  return str + ", " + str;

}

function capitalize (str) {

  return str[0].toUpperCase() + str.substring(1);

}

function exclaim (str) {

  return str + '!';

}

//这三个链式表达式写法:

// 传统的写法

exclaim(capitalize(doubleSay('hello')))

// "Hello, hello!"

// 管道的写法

'hello'

  |> doubleSay

  |> capitalize

  |> exclaim

// "Hello, hello!"

管道运算符只能传递一个值,这意味着它右边的函数必须是一个单参数函数。如果是多参数函数,就必须进行柯里化,改成单参数的版本。

首先说一下柯里化是什么

// 普通的函数

function fn(a,b) {

    return a+b

}

//柯里化后

function cfn(a) {

    return function (b) {

        return a + b

    }

}

fn(5, 2)         

cfn(5)(2)   

function double (x) { return x + x; }

function add (x, y) { return x + y; }

let person = { score: 25 };

person.score

  |> double

  |> (_ => add(7, _))

// 57

上面代码中,add函数需要两个参数。但是,管道运算符只能传入一个值,因此需要事先提供另一个参数,并将其改成单参数的箭头函数_ => add(7, _)。这个函数里面的下划线并没有特别的含义,可以用其他符号代替,使用下划线只是因为,它能够形象地表示这里是占位符。

具体执行就是将25传值给double得到50即第一个函数得执行结果,然后再将50传值给匿名函数返回add(x,y)函数默认x得值未7,"_"为占位符他会等于上一个结果得那个50所以最后得值为57.

管道运算符对于await函数也适用。

x |> await f

// 等同于

await f(x)

const userAge = userId |> await fetchUserById |> getAgeFromUser;

// 等同于

const userAge = getAgeFromUser(await fetchUserById(userId));

关于“ES6管道运算符怎么用”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识,可以关注编程网行业资讯频道,小编每天都会为大家更新不同的知识点。

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

ES6管道运算符怎么用

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

下载Word文档

猜你喜欢

es6新增的运算符怎么使用

这篇文章主要讲解了“es6新增的运算符怎么使用”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“es6新增的运算符怎么使用”吧!es6新增运算符有:1、可选链运算符“?.”,可以判断操作符之前属
2023-07-05

es6对象扩展运算符怎么应用

ES6的对象扩展运算符(`...`)可以用于复制对象、合并对象、传递函数参数等多种应用。复制对象:使用对象扩展运算符可以非常方便地复制一个对象。const obj1 = { name: 'Alice', age: 20 };const
2023-10-25

ES6扩展运算符如何使用

这篇“ES6扩展运算符如何使用”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“ES6扩展运算符如何使用”文章吧。什么是spre
2023-06-17

php运算符运用之类型运算符怎么用

这篇文章将为大家详细讲解有关php运算符运用之类型运算符怎么用,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。类型运算符指的是instanceof。instanceof运算符是php5引进的。在此之前用is
2023-06-20

JavaScript运算符怎么用

这篇文章主要介绍了JavaScript运算符怎么用,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。JavaScript有什么特点1、js属于一种解释性脚本语言;2、在绝大多数浏
2023-06-14

JS运算符怎么用

这篇文章主要为大家展示了“JS运算符怎么用”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“JS运算符怎么用”这篇文章吧。算术运算符对数值类型的变量及常量进行算数运算。也是最简单和最常用的运算符号。
2023-06-29

php运算符运用之怎么使用基本赋值运算符

这篇文章主要介绍了php运算符运用之怎么使用基本赋值运算符,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。php中基本的赋值运算符是“=”。他的优先级别低于其他的运算符,所以对
2023-06-20

如何正确的使用ES6扩展运算符

本篇文章给大家分享的是有关如何正确的使用ES6扩展运算符,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。什么是spread 和rest运算符spread和rest运算符在ES6中
2023-06-20

C#的sizeof运算符和三元运算符怎么用

本文小编为大家详细介绍“C#的sizeof运算符和三元运算符怎么用”,内容详细,步骤清晰,细节处理妥当,希望这篇“C#的sizeof运算符和三元运算符怎么用”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。实例usi
2023-06-17

怎么使用Python运算符

本篇内容介绍了“怎么使用Python运算符”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!Python语言支持很多种运算符,我们先用一个表格为
2023-06-01

编程热搜

目录