0

您能否建议如何解决以下错误:

ErrorException [ Fatal Error ]: Cannot use object of type Model_Branch as array

请看控制器:


public function action_view($agent_id='') {
        $agent =  ORM::factory('agent', $agent_id);

        if ($agent->loaded()) {

            $values = $agent->as_array();
            $branches = $agent->branches->find_all()->as_array();

            // Show page
            $this->template->title = $agent->company_name;
            $this->template->content = View::factory('agent/view')
                    ->bind('title', $this->template->title)
                    ->bind('values', $values)
                    ->bind('branches', $branches);
        } else {
            Request::instance()->redirect('agent');
        }
    }
4

2 回答 2

0

我会试试这个:

$branches = $agent->branches->find_all();
$branches = $branches->as_array();

它可能会起作用,有时您需要在转换之前声明它。

于 2010-12-03T17:49:58.443 回答
0

你真的不需要 as_array() 那里。默认情况下,Database_Result 对象表现为数组,您foreach ($branches as $b) echo $b->id甚至无需将其转换为数组即可;

Database_Result implements Countable, Iterator, SeekableIterator, ArrayAccess

正如我在此处指出的那样,Database_Result::as_array() 方法的唯一当前用途是生成 key => val 数组。您目前无法将其转换为数据库结果数组,尽管乍一看似乎是合乎逻辑的

于 2010-12-03T18:54:30.030 回答