php $db->select()->from()->where();

一个对象,方法后调用方法

过程是怎么执行的,是先返回第一个方法select()的东西,再执行第二个方法from(),再执行后面的方法吗?

阅读 7.3k
5 个回答

其实很简单啊,方法都是对一个对象属性做操作,最后都返回本身就可以用这种链式方法的说。一个简单的例子大概是这样的:

<?php
// http://3v4l.org/V3VuZ
class database {
    public $sql = "";
    public function select( $str = "" ) {
        $this->sql .= $str;
        return $this;
    }
    public function from( $str = "" ) {
        $this->sql .= $str;
        return $this;
    }
    public function __toString() {
        return $this->sql;
    }
}

$db = new database();
echo $db->select("abc")->from("def");

你应该说的是链式操作吧,题目里写的语句,只是单纯的构造查询语句而已,还要执行 $db->query() 才有结果集,类似这样 $db->query($db->select()->from()->where())。上面的构造语句里,每个方法里,都返回对象本身 return $this,所以又可以接着执行接在后面的方法。

其实就是返回了当前操作的对象,$this,这样一来就可以实现链式操作了!

撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进
推荐问题