11 月,我们将推出我们心爱的 PHP 8.4 版本,随之而来的是社区期待已久的新功能:属性挂钩!受到 C#、Swift 和 Kotlin 等其他语言的启发,这个新功能消除了魔法方法 __set() 和 __get() 的麻烦。
我将展示一个示例,说明当前如何拥有 getter 和 setter,而无需将属性创建为私有属性并创建两个名称与属性不同的新方法。
class Foo { private String $bar; public function __set($name, $value) { $this->$name = $value . "!!!"; } public function __get($name) { return "!!!" . $this->$name; } }
使用 __get() 和 __set() 当我设置值和查找值时,我可以将 $bar 保留为公共,但具有不同的实现,并且不必创建具有除属性之外的名称的方法。在视觉示例中,用法如下所示:
$foo = new Foo(); $foo->bar = "new release"; // aqui o valor que ficará salvo seria "new release!!!" echo $foo->bar; // aqui retornaria "!!!new release!!!"
现在想象一下 __get() 和 __set() 与其他属性一起使用会是什么样子,一团糟。另一种方法是创建一个 getBar() 方法和另一个 setBar() 方法,但这只考虑一个属性,用法与前一个不同:
class Foo { private String $bar; public function setBar($value) { $this->bar = $value . "!!!"; } public function getBar() { return "!!!" . $this->bar; } } $foo = new Foo(); $foo->setBar('new release'); // aqui o valor que ficará salvo seria "new release!!!" echo $foo->getBar(); // aqui retornaria "!!!new release!!!"
我个人觉得为此用例创建新方法有点烦人,我更喜欢使用属性的直接调用来获取和设置其值。这个新功能的出现是为了解决这个混乱问题,并允许您与类中的声明一起单独定义 get 和 set。
class Foo { public String $bar { set (String $value) => $this->bar = $value . "!!!"; get => "!!! . $this->bar"; } }
这个新代码做了同样的事情,但单独执行,没有创建新方法或使用需要处理类拥有的每个属性的 __get() 和 __set()。
现在就等待这个新功能的发布吧,预计将于 11 月 21 日发布!
免责声明: 提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发到邮箱:[email protected] 我们会第一时间内为您处理。
Copyright© 2022 湘ICP备2022001581号-3