php - 从多维数组创建 Html 元素

标签 php html arrays multidimensional-array

不知道如何解释这一点,但我们开始

我有一个数组如下:

$arr = array(
    array('id' => 1,
        'content' => '<h1>This is a simple Content</h1>',
        'vars' => null,
        'path' => 'holders/row.php',
        'sub-page' => array(
            'id' => 2,
            'content' => '<h1>Sample Body Here</h1>',
            'vars' => '{"title":"Sample Title Here"}',
            'path' => 'holders/box.php',
            'sub-page' => array(
                'id' => 3,
                'vars' => '{"title":"Sample Title NUmber 3 Here"}',
                'content' => '<h1>Again Sample Body Here</h1>',
                'path' => 'holders/box.php'
            )
        )
    )
);

我正在寻找的是 数组应该转到最深的子页面json_decode vars键并提取为变量并包含文件。

完成后,输出将传递到父级的内容键并再次解析它

这基本上是为了创建动态内容

holders/row.php 包含:

<div class="row">
    <?= $content; ?>
</div>

holders/box.php包含:

<div class="box lite">
    <div class="box-title">
        <h4><?= $title; ?></h4>

        <div class="tools">
            <a href="javascript:;" class="collapse">
                <i class="fa fa-chevron-up"></i>
            </a>
        </div>
    </div>
    <div class="box-body">
        <?= $content; ?>
    </div>
</div>

所需的输出是:

<div class="row">
    <div class="box lite">
        <div class="box-title">
            <h4>Sample Title Here</h4>

            <div class="tools">
                <a href="javascript:;" class="collapse">
                    <i class="fa fa-chevron-up"></i>
                </a>
            </div>
        </div>
        <div class="box-body">
            <h1>Again Sample Body Here</h1>

            <div class="box lite">
                <div class="box-title">
                    <h4>Sample Title NUmber 3 Here</h4>

                    <div class="tools">
                        <a href="javascript:;" class="collapse">
                            <i class="fa fa-chevron-up"></i>
                        </a>
                    </div>
                </div>
                <div class="box-body">
                    <h1>Again Sample Body Here</h1>
                </div>
            </div>
        </div>
    </div>
</div>

到目前为止我尝试了什么

我正在尝试按如下方式循环数组:

foreach ($arr as &$page) {
    if (isset($page[$keyToParse])) {
        $subMenu = $page[$keyToParse];
        unset($page[$keyToParse]);
        $page['content'] = $page['content'] . $this->parsePage($keyToParse, $subMenu);
        return $page['content'];
    } else {
        $params = strlen($page['vars']) > 0 ? json_decode($page['vars'], true) : [];
        $elementPath = $page['path'];
        $params = array_merge($params, array('content' => $page['content']));
        $page['content'] = callback(function () use ($params, $elementPath) {
            extract($params);
            include($elementPath);
        });

        return $page['content'];
    }

回调函数如下:

function callback($userfunc)
{
    ob_start();
    $userfunc();
    $return = ob_get_contents();
    ob_end_clean();
    return $return;
}

请帮忙,因为我被困了很长时间

最佳答案

您所要做的就是这样。

function renderNode($node){
        ob_start();
        if (isset($node["sub-page"]) && $node["sub-page"]){
                $node["content"] = renderNode($node["sub-page"]);
        }
        extract($node);
        include ($node["path"]);
        return ob_get_clean();
}

然后像这样调用它:

echo renderNode($arr[0]);

关于php - 从多维数组创建 Html 元素,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/23726918/

相关文章:

html - 如何更改 ionic 标题的颜色?

Java(swing)仅绘制屏幕上可见的内容

java - 如何修复 NullPointerException 错误

php - 使用数据:image/jpeg;base64?有什么风险

javascript - 如何将javascript排入wordpress子主题

javascript - 从 div 属性驱动 dimple.js 图表

javascript - 通过 html jquery 验证的自定义消息未显示

php - 如何使用 ajax 和 json 返回多个数据

php - 如何在现有 CMS 旁边安装 Wordpress?

javascript - 我可以搜索一组函数并运行搜索到的函数吗?