像这样创建一个“指南栏”,在php + mysql的网页上面?

时间:2009-12-02 15:01:40

标签: php breadcrumbs

我想创建一个“指南栏”(我不知道它的正确名称)。我有一个名为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

2 个答案:

答案 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