短闭包,也叫做箭头函数,是一种用 php 编写的短函数.当向函数中传递闭包时,这个功能是非常有用的,比如使用 array_map 或是 array_filter函数时.
这就是它们看起来的样子:
// Post 对象的集合 $posts = [/* … */]; $ids = array_map(fn($post) => $post->id, $posts);
而以前,你必须这样写:
$ids = array_map(function ($post) { return $post->id; }, $posts);
我们来总结一下短闭包函数如何使用.
在 PHP 7.4 里可用
上面示例更严格的类型限定写法可写作:
$ids = array_map(fn(Post $post): int => $post->id, $posts);
有两点需要提及:
假如你想要通过引用的方式返回结果,应该使用以下语法:
fn&($x) => $x
简而言之,除了只允许一个表达式以外,简短的闭包和普通闭包的功能是一样的。
单行
你应该正确的理解它:短闭包只能有一个表达式。这意味着闭包体中不能有多行。
原因如下:短闭包的目的是为了减少冗余。当然,在任何情况下, fn 都比 function 短。然而, RFC 的创建者 Nikita Popov 认为,如果你要处理的是多行表达式的函数,那么使用闭包获得的益处就更少了。
毕竟,多行闭包的定义已经很冗余了,所以,有和没有这2个关键字( function 和 return )将不会有太大区别。
你是否同意这个观点取决于你自己。虽然我可以在我的项目中想到很多单行闭包的场景,但也有很多多行闭包的情况,从个人角度,我会喜欢这些情况下的简短语法。
不过还是有希望的:未来可能会添加多行短闭包,但那也是一个单独的 RFC 。
外部作用域的值
短闭包和普通闭包的另一个显著特征是,短闭包不需要用 use 关键字就能访问外部作用域的数据。
$modifier = 5; array_map(fn($x) => $x * $modifier, $numbers);
需要注意的是,不能修改外部范围中的变量。因为它属于值传递而不是引用传递。这意味着你可以改变短闭包内的 $modifier 变量,但它不会对外部作用域中的 $modifier 变量产生影响。
当然,有一个例外,那就是 $this 关键字,它的作用与普通闭包中的作用完全相同:
array_map(fn($x) => $x * $this->modifier, $numbers);
发展前景
我已经提到过的多行闭包仍然是将来的一个发展可能.另外一个在我脑海中的想法就是在允许在类中使用短闭包,比如 getters 和 setters 函数.
class Post { private $title; fn getTitle() => $this->title; }
总而言之,短闭包是一个很受欢迎的特性,尽管有很多地方需要提高.其中最有可能就是多行闭包了.
总结
以上所述是小编给大家介绍的PHP 7.4 新语法之箭头函数实例详解,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对小牛知识库网站的支持!
如果你觉得本文对你有帮助,欢迎转载,烦请注明出处,谢谢!
本文向大家介绍ES6中的箭头函数实例详解,包括了ES6中的箭头函数实例详解的使用技巧和注意事项,需要的朋友参考一下 本文实例讲述了ES6中的箭头函数。分享给大家供大家参考,具体如下: 语法 我们先来看看箭头函数的语法: param 是参数,根据参数个数不同,分这几种情况: 示例 我们再来看看一些示例,看看在ES5中的函数怎么通过ES6中的箭头函数来替代吧: 当然,也可以定义多个参数: 当然=>后面
在“功能”部分中,它说 该= 注意:在箭头(= 但是在“匿名函数”部分中,它说 如果函数只包含一个语句,则可以使用箭头表示法缩短它 这是否意味着我可以在匿名函数中使用不是表达式的语句(例如if语句)? 还是我混淆了表达和陈述的概念?我想 表达式:可以求值为一个值(2 3,print(")也属于表达式) 语句:可以执行的代码。所有表达式都可以是语句。如果语句和返回语句是不是表达式的语句的示例。 如果
不鼓励将箭头函数(“lambdas”)传递给 Mocha。Lambdas词法绑定 this,无法访问 Mocha 上下文。例如,以下代码将失败: describe('my suite', () => { it('my test', () => { // should set the timeout of this test to 1000 ms; instead will fail thi
ES6标准新增了一种新的函数:Arrow Function(箭头函数)。 为什么叫Arrow Function?因为它的定义用的就是一个箭头: x => x * x 上面的箭头函数相当于: function (x) { return x * x; } 在继续学习箭头函数之前,请测试你的浏览器是否支持ES6的Arrow Function: 'use strict'; ---- var f
本文向大家介绍ES6箭头函数和扩展实例分析,包括了ES6箭头函数和扩展实例分析的使用技巧和注意事项,需要的朋友参考一下 本文实例讲述了ES6箭头函数和扩展。分享给大家供大家参考,具体如下: 1.默认值 在ES6中给我们增加了默认值的操作相关代码如下: 可以看到现在只需要传递一个参数也是可以正常运行的。 输出结果为:2。 2.主动抛出错误 ES6中我们直接用throw new Error( xxxx
新的“胖箭头”符号还可以用更简单的方式来定义匿名函数。 请看下面的例子: console.log(x); incrementedItems.push(x+1); }); 计算一个表达式并返回值的函数可以被定义更简单: 下面代码与上面几乎等价: incrementedItems = items.map(function (x) { return x+1; 让我们在 验