我在我的模型的函數:從陣列中使用數據,而無需的foreach
public function get_learning_category_list() {
$categorias = $this->db->select('t1.id, t1.title, t1.metadata, t1.meta_title, t1.description, t1.meta_description, t1.meta_spam, t1.url, t1.alt_img')
->from('learning_category t1')
->join('learning_rel_category t4', 't1.id = t4.category_id', 'left')
->join('learning t2', 't4.learning_id = t2.id', 'left')
->join('learning_rel_language t3', 't2.id = t3.learning_id', 'left')
->where('t3.language', $this->language)
->group_by('t1.id')
->get()->result_array();
foreach($categorias as $c){
$total = $this->db->select('count(learning_rel_language.learning_id) as total', false)
->from('learning')
->join('learning_rel_language', 'learning.id = learning_rel_language.learning_id', 'inner')
->join('learning_rel_category', 'learning.id = learning_rel_category.learning_id', 'inner')
->where('learning_rel_category.category_id', $c['id'])
->where('learning_rel_language.language', $this->language)
->group_by('learning_rel_language.language')->get()->first_row('array');
$metadata = json_decode($c['metadata']);
$tt = $c['title'];
$url = $c['url'];
if($this->language != 'pt_br'){
$tt = $metadata->{$this->language};
$tt_pt_br = $c['title'];
}
$return[] = array('url' => $url, 'title'=>$tt, 'id'=>$c['id'], 'total'=>$total['total'], 'title_pt_br'=>$tt_pt_br);
}
return $return; //$categorias;
}
它導致我所學的知識列表中的數組:
Array ([0] => Array ([url] => [title] => Cursos sobre como gerar leads qualificados [id] => 2 [total] => 6 [title_pt_br] =>) [1] => Array ([url] => [title] => Cursos de Social Media Marketing [id] => 3 [total] => 2 [title_pt_br] =>) [2] => Array ([url] => [title] => Cursos de SEO e otimização de sites [id] => 4 [total] => 3 [title_pt_br] =>)
但我需要使用數據從這些學習(標題,ID等)在另一個功能模型:
public function url_format_category($category, $lang_domin) {
if (lang('abbr') == 'en_US')
$lang_domin = 'en/';
else if (lang('abbr') == 'es_US')
$lang_domin = 'es/';
$categorias = $this->learn->get_learning_category_list();
print_r($categorias);
foreach($categorias as $cat){
print_r($cat);
$cat = (object) $cat;
if($cat->title != '') {
$return = strtolower(url_title($cat->title)).'-cmdo-'.$cat->id;
}else{
$return = 'cursos-de-marketing-digital-online-'.$cat->id;
}
return $return;
}
我這樣做,但與foreach總是結果我ñ相同的獨立數據,我的網頁。如何在不使用foreach的情況下使用此數組中的數據?
看着代碼,'return'在foreach循環中 – Ghost
對不起,我是編程新手。我把退貨了嗎? – GWER
如果你打算處理數組內的所有項目,那麼你需要在外面完成,然後返回你的預期結果 – Ghost