我想创建一个“指南栏”(我不知道它的正确名称)。我有一个名为cat
的表格,其中包含以下数据:
catid catname parentid 1 news null 2 sport 1 3 health 1 4 tennis 2 5 football 2 6 soccer 5
我的页面收到:$catid=6
,我想创建:
news>sport>football>soccer
答案 0 :(得分:3)
首先从数据库获取数据并构建数组
$q = mysql_query("SELECT catid, catname, parentid FROM cat");
$pages = array();
while($r = mysql_fetch_assoc($q)) {
$pages[$r['catid']] = array('catname' => $r['catname'], 'parentid' => $r['parentid']);
}
使用递归函数构建面包屑:
function build_breadcrumbs($pages, $catid) {
if(is_null($catid) || empty($catid)) return;
return build_breadcrumbs($pages, $pages[$catid]['parentid']).$pages[$catid]['catname'].' > ';
}
该函数返回父代的面包屑+当前的痕迹。使用这样的功能:
$catid = 6;
$breadcrumbs = trim(build_breadcrumbs($pages, $catid), ' >');
echo $breadcrumbs;
或者,如果你更喜欢数组,你可以创建一个这样的函数:
function build_breadcrumbs($pages, $catid) {
if(is_null($catid) || empty($catid)) return array();
return array_merge(build_breadcrumbs($pages, $pages[$catid]['parent']), array($pages[$catid]['name']));
}
并将其与implode一起使用:
$catid = 6;
$breadcrumbs = implode(' > ', build_breadcrumbs($pages, $catid));
echo $breadcrumbs;
这使您可以选择在函数外部定义分隔符。希望有所帮助。
答案 1 :(得分:1)
它们被称为面包屑。这里有一个可能有用的教程:http://www.mindpalette.com/tutorials/breadcrumbs/index.php