0

我的数据库中有几个类别,我正在使用类似这样的嵌套集模型检索它们(括号中的数字代表深度):

新(1)
-常规(2) -
控制台(2)

游戏(1)
-pc(2)
--emulator(3)
-ps3(2)

然后我有一个函数来处理多维数组并生成导航菜单——这个

模型
从数据库中返回以下数组

Array (
    [0] => Array ( [name] => News [depth] => 1 ) 
    [1] => Array ( [name] => General [depth] => 2 ) 
    [2] => Array ( [name] => Console [depth] => 2 ) 
    [4] => Array ( [name] => Games [depth] => 1 ) 
    [5] => Array ( [name] => PC [depth] => 2 ) 
    [6] => Array ( [name] => emulator [depth] => 3 ) 
    [8] => Array ( [name] => ps3 [depth] => 2 ) 
) 

--控制器

public function index()
{
$navTree = $this->getNavTree(); //gets array from model
$createNavTree = $this->_renderTree($navTree); //pass array to function
$this->load->view('testnavigation.php', $createNavTree);
}


function _renderTree($tree){    
    $current_depth = 0;
    $counter = 0;

    $result = '';

    foreach($tree as $node){
        $node_depth = $node['depth'];
        $node_name = $node['name'];
        $node_id = $node['categoryid'];

        if($node_depth == $current_depth){
            if($counter > 0) $result .= '</li>';            
        }
        elseif($node_depth > $current_depth){

            $result .= $counter == 0 ? '<ul id="nav">' : '<ul>';
            $current_depth = $current_depth + ($node_depth - $current_depth);
        }
        elseif($node_depth < $current_depth){
            $result .= str_repeat('</li></ul>',$current_depth - $node_depth).'</li>';
            $current_depth = $current_depth - ($current_depth - $node_depth);
        }
        $result .= '<li><a href="#">'.$node_name.'</a>';
        ++$counter;
    }
    $result .= str_repeat('</li></ul>',$node_depth).'</li>';
    $result .= '</ul>';     
    return $result;
}

- 看法

echo $createNavTree;

该列表以正确的缩进顺序创建,但是我遇到的问题是为每个项目生成链接,例如模拟器的链接应该是 mysite.com/games/pc/emulator

我将如何实现这一目标,感谢您的帮助?

4

1 回答 1

0

我会采取简单的路线并为每个级别构建一组缓存级别和先前计算的路径。当再次看到的“基础级别”1时,清除缓存,这样您就没有任何无效条目:

此示例代码应该适用于您当前拥有的代码(只需将此代码放在您当前的布局渲染代码上方并$path用作 URL):

function _renderTree($tree) {
    $depths = array();
    foreach ($tree as $node) {
        // build the current path
        $path = (($node['depth'] > 1) ? $depths[$node['depth'] - 1] : '') . $node['name'];

        // set the current path as the current depth's path (to be used for any deeper-nodes)
        $depths[$node['depth']] = $path . '/';

        ... layout rendering code ...
    }
}

它的作用是,如果当前路径depth高于 1(这意味着存在父级深度),它将采用父级的计算路径(应该是父级的完整路径,而不仅仅是父级的名称),然后将当前名称添加到其中 - 这将为您提供完整的嵌套路径。然后,它将生成的路径存储到$depths数组中(以当前深度为索引)供任何子级使用。

在您的示例中,您指定要为的路径Emulatormysite.com/games/pc/emulator强调小写和域名。由于我们$node['name']在我们的路径中使用,你会想要使用strtolower()

$path = (($node['depth'] > 1) ? $depths[$node['depth'] - 1] : '') . strtolower($node['name']);

<a></a>我建议在标签的实际行中添加域名:

$result .= '<li><a href="http://mysite.com/' . $path . '">'.$node_name.'</a>';
于 2012-10-08T12:41:58.650 回答