博客
关于我
php中的方法链
阅读量:120 次
发布时间:2019-02-26

本文共 836 字,大约阅读时间需要 2 分钟。

在许多流行的编程框架中,比如Zend、CakePHP等,人们常常使用如下的类方法调用方式:$obj->foo()->bar()->anotherMethod();。这其实是PHP中的方法链调用机制的应用。通过一个简单的例子,我们可以更好地理解这一点。

以下是一个完整的类定义示例:

class Person {    private $name;    private $age;    public function setName($Name) {        $this->name = $Name;        return $this; // 返回当前对象    }    public function setAge($Age) {        $this->age = $Age;        return $this; // 返回当前对象    }    public function findMe() {        echo "My name is " . $this->name . " and I am " . $this->age . " years old.";    }}

正常的调用方式如下:

$myself = new Person();$myself->setName('Arvind Bhardwaj');$myself->setAge('22');$myself->findMe();

而使用方法链的优化方式则可以简化为:

$myself = new Person();$myself->setName('Arvind Bhardwaj')->setAge('22')->findMe();

这种方法链的调用方式在PHP中被广泛应用,特别是在需要多次调用相关方法的情况下。它的核心原理是每个方法都返回当前对象(return $this;),从而允许方法链的连续调用。这种写法不仅简化了代码,也提高了代码的可读性和维护性。

转载地址:http://lrif.baihongyu.com/

你可能感兴趣的文章
Objective-C实现bellman ford贝尔曼福特算法(附完整源码)
查看>>
Objective-C实现bellman-ford贝尔曼-福特算法(附完整源码)
查看>>
Objective-C实现bellman-ford贝尔曼-福特算法(附完整源码)
查看>>
Objective-C实现BellmanFord贝尔曼-福特算法(附完整源码)
查看>>
Objective-C实现bfs 最短路径算法(附完整源码)
查看>>
Objective-C实现BF算法 (附完整源码)
查看>>
Objective-C实现Bilateral Filter双边滤波器算法(附完整源码)
查看>>
Objective-C实现binary exponentiation二进制幂运算算法(附完整源码)
查看>>
Objective-C实现binary tree mirror二叉树镜像算法(附完整源码)
查看>>
Objective-C实现binary tree traversal二叉树遍历算法(附完整源码)
查看>>
Objective-C实现binomial coefficient二项式系数算法(附完整源码)
查看>>
Objective-C实现bisection二分法算法(附完整源码)
查看>>
Objective-C实现bisection二等分算法(附完整源码)
查看>>
Objective-C实现BitMap算法(附完整源码)
查看>>
Objective-C实现bitonic sort双调排序算法(附完整源码)
查看>>
Objective-C实现bogo sort排序算法(附完整源码)
查看>>
Objective-C实现boruvka博鲁夫卡算法(附完整源码)
查看>>
Objective-C实现Boyer-Moore字符串搜索算法(附完整源码)
查看>>
Objective-C实现BP误差逆传播算法(附完整源码)
查看>>
Objective-C实现breadth First Search广度优先搜索算法(附完整源码))
查看>>