Я столкнулся с проблемой при передаче массива от контроллера к модели в Code Igniter для дальнейшей обработки.Передача массива от контроллера к модели CodeIgniter
Контроллер:
public function list_out(){
$this->show_pagination();
$action = array(
'page'=>'public/'.$this->class_name.'/list',
'title'=>'My Title',
'success'=>$this->success,
'data'=>$this->public_model->my_function(array('make'=>'Apple','color'=>'Black'))
);
$this->public_page($action);
}
Модель:
public function my_function($arr){
$this->db->select('main_tbl.*,image_table.image_url');
$this->db->from('main_tbl');
$this->db->join('image_tbl','image_tbl.prod_id=main_tbl.prod_id');
$this->db->where('main_tbl.prod_status',1);
$table = 'main_tbl';
for ($i = 0; $i < count($arr); $i++) {
$key=key($arr);
$val=$arr[$key];
if ($val<> ' ') {
$this->db->where($table.'.'.$key,$val);
}
next($arr);
}
$this->db->where('image_tbl.image_cover',1);
$this->db->order_by('prod_id','desc');
$query = $this->db->get();
return $query->result();
}
Ошибка:
Сообщение: ключ() ожидает параметр 1, чтобы быть массив, строка, заданная сообщение: следующая() ожидает, что параметр 1 является массивом, указанная строка
Когда тот же массив размещен внутри my_function() в Model, он работает хорошо.
Ex:
public my_function(){
$arr = array(
'make'=>'Apple',
'color'=>'Black'
);
$this->db->select('main_tbl.*,image_table.image_url');
........
}
Что может быть проблема здесь? Любая помощь будет высоко оценен.
Заранее спасибо.