thinkphp实现面包屑导航(当前位置)例子分享

2015-01-24信息快讯网

今天把博客一些细节完善了一下,其中修改了一下栏目页和文章页中的“当前位置”。

以前栏目很少,就用死办法做的(首页 -> 栏目的名字),现在栏目多了,渐渐二级栏目,三级栏目也来了,这样的方式显然不太合适,于是就改进了一下。也不难,利用一个递归函数就可以了。

使用例子:

//当前位置-第一个参数 catid为当前栏目的id,第二个参数为文章的标题,调用栏目当前位置时第二个参数为空即可。
$this->assign("now_here",$this->now_here($catid,$res['title']));

实现代码:

//解释一下,栏目表category中的catid为栏目id,catname为栏目名称,asmenu为栏目父级的id,当为顶级栏目时,asmenu为0 。 protected function now_here($catid,$ext=''){ $cat = M("Category"); $here = '<a href="http://www.jb51.net">首页</a>'; $uplevels = $cat->field("catid,catname,asmenu")->where("catid=$catid")->find(); if($uplevels['asmenu'] != 0) $here .= $this->get_up_levels($uplevels['asmenu']); $here .= ' -> <a href="/cat_'.$uplevels['catid'].'.html">'.$uplevels['catname']."</a>"; if($ext != '') $here .= ' -> '.$ext; return $here; } protected function get_up_levels($id){ $cat = M("Category"); $here = ''; $uplevels = $cat->field("catid,catname,asmenu")->where("catid=$id")->find(); $here .= ' -> <a href="/cat_'.$uplevels['catid'].'.html">'.$uplevels['catname']."</a>"; if($uplevels['asmenu'] != 0){ $here = $this->get_up_levels($uplevels['asmenu']).$here; } return $here; }



附:另一个例子

class IndexAction extends Action {

public function cat() { load('extend'); // 加载 extend.php 文件 // 取出所有的分类 $Categories = M('Categories')->select();

$nav_array = array(); $this->getNavCrumbs($Categories, 2120, $nav_array); dump($nav_array);

// 取出所有分类(并构造成一棵树) // $CategoryTree = list_to_tree($Categories, 'categories_id', 'parent_id'); }

/** * 根据分类id向上回溯构造面包屑 * @param $Categories 由所有分类组成的数组 * @param $categoryId 要进行向上回溯用的分类id * @param $navCrumbs 用于保存结果的数组,传入一个空数组就好 */ public function getNavCrumbs($Categories, $categoryId, &$navCrumbs) { $category = list_search( $Categories, array('categories_id'=>$categoryId) ) ; $category = $category[0]; $parent_id = $category['parent_id']; $categories_id = $category['categories_id'];

if( $parent_id != 0 ) { // 这里的 0 是根节点id(root节点id) $this->getNavCrumbs($Categories, $parent_id, $navCrumbs); }

$navCrumbs[$categories_id] = $category; }

}


©2014-2024 dbsqp.com