0

我试图更新Collin James 的这个出色的解决方案以在Laravel 4中工作。

直到知道没有运气。这就是我想出的:

/app/libraries/Model.php(我已经使用 composer 注册了库目录)

namespace Elegant;

class Model extends \Illuminate\Database\Eloquent\Model {
    function __construct() 
    {
        echo 'Show me if the Model exension works<br />';
    }

    protected function query()
    {
        echo 'Show me if the query function gets called<br />';
        return new \Elegant\Query($this);
    }
}

/app/libraries/Query.php(我已经使用composer注册了库目录)

namespace Elegant;

class Query extends \Illuminate\Database\Query {

    public function __construct() 
    {
        echo 'Show me if the Query exension works<br />';
    }

    public function byArray($column, $value) 
    {
        if (is_array($value))
            return $this->whereIn($column, $value);
        else
            return $this->where($column, '=', $value);
    }

    public function __call()
    {
    }
}

/app/config/app.php

'aliases' => array(
    ...
    'Eloquent'        => 'Elegant\Model',
    ...
)

唯一有效的是:

  • “告诉我模型扩展是否有效”。

其他“标记”不起作用:

  • query() 根本没有被调用
  • 使用 Eloquent/Query,而不是先看 Elegant/Query
4

1 回答 1

0

QueryScopes 是您的意思吗?http://laravel.com/docs/eloquent#query-scopes 您可以为查询添加自定义范围。您还可以添加额外的参数,但始终添加 $query(并且是当前查询)可能类似于:

public function scopeByArray($query, $column, $value)
{
    if (is_array($value))
        return $query->whereIn($column, $value);
    else
        return $query->where($column, '=', $value);
}

然后就User::byArray($column, $value)->orderBy(..)

你可以扩展 Eloquent 并在其中添加函数 ( class BaseModel extends Eloquent)

于 2013-06-12T15:07:07.503 回答