1

我正在设置分页以显示属于用户帐户中的图像列表。这就是我的控制器中的内容:

class UsersController extends AppController {

    public $paginate = array(
        'limit' => 5,
        'order' => array(
            'Image.uploaded' => 'DESC'
        )
    );

    // ...

    public function images() {
        $this->set('title_for_layout', 'Your images');

        $albums = $this->Album->find('all', array(
            'conditions' => array('Album.user_id' => $this->Auth->user('id'))
        ));
        $this->set('albums', $albums);

        // Grab the users images
        $options['userID'] = $this->Auth->user('id');
        $images = $this->paginate('Image');
        $this->set('images', $images);
    }

    // ...

}

它可以工作,但在我实现这个分页之前,我的Image模型中有一个自定义方法来获取用户图像。这里是:

public function getImages($options) {
    $params = array('conditions' => array());

    // Specific user
    if (!empty($options['userID'])) {
        array_push($params['conditions'], array('Image.user_id' => $options['userID']));
    }

    // Specific album
    if (!empty($options['albumHash'])) {
        array_push($params['conditions'], array('Album.hash' => $options['albumHash']));
    }

    // Order of images
    $params['order'] = 'Image.uploaded DESC';
    if (!empty($options['order'])) {
        $params['order'] = $options['order'];
    }

    return $this->find('all', $params);
}

有没有办法可以使用此getImages()方法而不是默认方法paginate()?我在文档中可以找到的最接近的内容是“自定义查询分页”,但我不想编写自己的查询,我只想使用该getImages()方法。希望我能做到。

干杯。

4

1 回答 1

1

是的。

//controller
$opts['userID'] = $this->Auth->user('id');
$opts['paginate'] = true;
$paginateOpts = $this->Image->getImages($opts);
$this->paginate = $paginateOpts;
$images = $this->paginate('Image');


//model
if(!empty($opts['paginate'])) {
    return $params;
} else {
    return $this->find('all', $params);
}

解释:

基本上,您只需添加另一个参数(我通常将其称为“分页”),如果它在模型中为真,则无需传回查找的结果,而是传回动态创建的参数 - 然后您可以使用这些参数来执行控制器中的分页。

这使您可以继续将所有模型/数据库逻辑保留在模型中,并且只需在模型根据您发送的选项构建所有复杂参数后利用控制器进行分页。

于 2012-07-12T23:13:28.137 回答