ecshop首页调用指定分类的文章的方法介绍
1 举例如首页调用方法: 2 1、先打开index.php文件找到以下代码: 3 $smarty->assign('new_articles', index_get_new_articles()); // 最新文章 4 在它下面增加以下: 5 //调用方法 6 $smarty->assign('class_articles_4', index_get_class_articles(4,6)); // 分类调用文章 7 //调用多个就修改传进去的参数,以及模板接收的变量,其中上面的4就是文章分类ID,其中6是调用数量 8 $smarty->assign('class_articles_5', index_get_class_articles(5,6)); // 分类调用文章 9 $smarty->assign('class_articles_6', index_get_class_articles(6,6)); // 分类调用文章 10 $smarty->assign('class_articles_7', index_get_class_articles(7,6)); // 分类调用文章 11 $smarty->assign('class_articles_8', index_get_class_articles(8,6)); // 分类调用文章 12 2、在lib_goods.php增加以下函数 13 /** 14 * 获得指定栏目最新的文章列表。 15 * 16 * @access private 17 * @return array 18 */ 19 function index_get_class_articles($cat_aid, $cat_num) 20 { 21 $sql = "SELECT article_id, title,open_type,cat_id,file_url FROM " .$GLOBALS['ecs']->table('article'). " WHERE cat_id = ".$cat_aid." and is_open = 1 LIMIT " . $cat_num; 22 $res = $GLOBALS['db']->getAll($sql); 23 $arr = array(); 24 foreach ($res AS $idx => $row) 25 { 26 $arr[$idx]['id'] = $row['article_id']; 27 $arr[$idx]['title'] = $row['title']; 28 $arr[$idx]['short_title'] = $GLOBALS['_CFG']['article_title_length'] > 0 ? 29 sub_str($row['title'], $GLOBALS['_CFG']['article_title_length']) : $row['title']; 30 $arr[$idx]['cat_name'] = $row['cat_name']; 31 $arr[$idx]['add_time'] = local_date($GLOBALS['_CFG']['date_format'], $row['add_time']); 32 $arr[$idx]['url'] = $row['open_type'] != 1 ? 33 build_uri('article', array('aid' => $row['article_id']), $row['title']) : trim($row['file_url']); 34 $arr[$idx]['cat_url'] = build_uri('article_cat', array('acid' => $row['cat_id'])); 35 } 36 return $arr; 37 } 38 3、第二步是在index.dwt模板想调用的地方增加以下代码,(注:以下调上面设置里的分类ID为8的文章列表): 39 <!--{foreach from=$class_articles_8 item=article}--> 40 <li><a href="{$article.url}" title="{$article.title|escape:html}"><!--{$article.short_title|truncate:15:true}--></a></li> 41 <!--{/foreach}-->