如何循环多维数组

时间:2018-12-19 15:01:24

标签: arrays smarty

在Smarty中,如何在我的第二个foreach中循环子值?

[test] => stdClass Object
        (
            [parent] => Test
            [sub] => Array
                (
                    [0] => Array
                        (
                            [key1] => Value 1
                            [key2] => Value 2
                        )

                )

        )

 {foreach from=$menuList item=menu}
    <li><a href="#">{$menu->name}</a>
        <ul class="dropdown-menu">
          {foreach from=$menu->sub key=k item=v}
                <li class="dropdown-submenu" name=>{$v}</li>
          {/foreach}
        </ul>
    {/foreach}
 </li>

如何为每个打印第二个?

仅打印数组字符串

2 个答案:

答案 0 :(得分:0)

首先,您的“数组”实际上是对象。您需要先将其转换为数组才能使用该功能。这是可以执行此操作的函数:

function objectToArray($d) {
    if (is_object($d)) {
        // Gets the properties of the given object
        $d = get_object_vars($d);
    }
    if (is_array($d)) {
        /*
        * Return array converted to object
        * Using __FUNCTION__ (Magic constant)
        * for recursive call
        */
        return array_map(__FUNCTION__, $d);
    }
    else {
        // Return array
        return $d;
    }
}

很明显,这是php函数,可以将其放在php文件或smarty插件中以进行访问。然后,这是一个使用前一个函数对对象或任何输入进行动态处理的函数。

function smarty_function_tree($params, &$smarty) {
if (!isset($params['level'])) {
    $level = 0;
    } else {
    $level = $params['level'];
}
return tree($params['data'], $level);
}

function tree($data, $level) {
echo '<ul class="level', $level, '">', "\r\n";
$aData = objectToArray($data);
foreach ($aData as $key => $entry) {
    if (is_array($entry)) {
        echo '<li>', $key, '</li>', "\r\n";
        tree($entry, $level+1);
    } else {
        echo '<li>', $key, ' = ', $entry, '</li>', "\r\n";
    }
}
    echo '</ul>', "\r\n";
}

创建一个对应于函数名称的插件,然后您可以在模板中使用它,如下所示:

{tree data=$yourObject}

{tree data=$yourArray}

编辑:您还可以使用CSS的litlebit缩进树函数的输出:

.level0 {
    text-indent: 20px;
}

.level1 {
    text-indent: 40px;
}

.level2 {
    text-indent: 60px;
}

.level3 {
    text-indent: 80px;
}

.level4 {
    text-indent: 100px;
}

.level5 {
    text-indent: 120px;
}

.level6 {
    text-indent: 140px;
}

.level7 {
    text-indent: 160px;
}

.level8 {
    text-indent: 180px;
}

.level9 {
    text-indent: 200px;
}

希望有帮助!

答案 1 :(得分:0)

如果您知道key1key2,则可以:

{foreach from=$menu->sub key=k item=v}
    key1 = {$v.key1}, key2 = {$v.key2}
{/foreach}

输出:

key1 = value1, key2 = value2

在您的示例中

{foreach from=$menuList item=menu}
    <li><a href="#">{$menu->name}</a>
        <ul class="dropdown-menu">
          {foreach from=$menu->sub key=k item=v}
                <li class="dropdown-submenu" name="{$v.key1}"></li>
          {/foreach}
        </ul>
    {/foreach}
 </li>

如果您不知道键,则需要另一个循环

{foreach from=$menu->sub key=k item=v}
    {foreach from=$v key=u item=i}
        {$u} = {$i},
    {/foreach}
{/foreach}

输出:

key1 = value1, key2 = value2,

如果您有 Object ,请使用->。如果您有 Array ,请使用.[]