使var_dump看起来很漂亮

问题描述 投票:106回答:12

我有一个简单的$_GET[]查询变量集,用于在从DB下拉查询时显示测试数据。

<?php if($_GET['test']): ?>
  <div id="test" style="padding: 24px; background: #fff; text-align: center;">  
    <table>
      <tr style="font-weight: bold;"><td>MLS</td></tr>
      <tr><td><?php echo KEY; ?></td></tr>
      <tr style="font-weight: bold;"><td>QUERY</td></tr>
      <tr><td><?php echo $data_q; ?></td></tr>
      <tr style="font-weight: bold;"><td>DATA</td></tr>
      <tr><td><?php var_dump($data); ?></td></tr>
    </table>    
</div>
<?php endif; ?>

当我做var_dump时,正如预期的那样,这个大阵列的字符串都被一起刷了。有没有办法至少为此添加换行符或以更可读的方式显示var_dump?我对jQuery有关在发布后操纵字符串的建议持开放态度。

php arrays var-dump
12个回答
310
投票

我真的很喜欢var_export()。如果您喜欢复制/粘贴代码,请尝试:

echo '<pre>' . var_export($data, true) . '</pre>';

或者甚至是这样的颜色语法突出显示:

highlight_string("<?php\n\$data =\n" . var_export($data, true) . ";\n?>");

0
投票
function var_view($var)
{

    ini_set("highlight.keyword", "#a50000;  font-weight: bolder");
    ini_set("highlight.string", "#5825b6; font-weight: lighter; ");

    ob_start();
    highlight_string("<?php\n" . var_export($var, true) . "?>");
    $highlighted_output = ob_get_clean();

    $highlighted_output = str_replace( "&lt;?php", '', $highlighted_output );
    $highlighted_output = str_replace( "?&gt;", '', $highlighted_output );

    echo $highlighted_output;
    die();
}

-2
投票

我写了一个函数(debug_display),可以很好地打印,数组,对象和文件信息。

<?php
function debug_display($var,$show = false) {
    if($show) { $dis = 'block'; }else { $dis = 'none'; }
    ob_start();
    echo '<div style="display:'.$dis.';text-align:left; direction:ltr;"><b>Idea Debug Method : </b>
        <pre>';
    if(is_bool($var)) {
        echo $var === TRUE ? 'Boolean(TRUE)' : 'Boolean(FALSE)';
    }else {
        if(FALSE == empty($var) && $var !== NULL && $var != '0') {
            if(is_array($var)) {
                echo "Number of Indexes: " . count($var) . "\n";
                print_r($var);
            } elseif(is_object($var)) {
                print_r($var);
            } elseif(@is_file($var)){
                $stat = stat($var);
                $perm = substr(sprintf('%o',$stat['mode']), -4);
                $accesstime = gmdate('Y/m/d H:i:s', $stat['atime']);
                $modification = gmdate('Y/m/d H:i:s', $stat['mtime']);
                $change = gmdate('Y/m/d H:i:s', $stat['ctime']);
                echo "
    file path : $var
    file size : {$stat['size']} Byte
    device number : {$stat['dev']}
    permission : {$perm}
    last access time was : {$accesstime}
    last modified time was : {$modification}
    last change time was : {$change}
    ";
            }elseif(is_string($var)) {
                print_r(htmlentities(str_replace("\t", '  ', $var)));
            }  else {
                print_r($var);
            }
        }else {
            echo 'Undefined';
        }
    }
    echo '</pre>
    </div>';
    $output = ob_get_contents();
    ob_end_clean();
    echo $output;
    unset($output);
}

-11
投票

使用

echo nl2br(var_dump());

这应该工作^^


37
投票

尝试xdebug扩展为PHP。

例:

<?php var_dump($_SERVER); ?>

输出:


17
投票

使用预先格式化的HTML代码

echo '<pre>';
var_dump($data);
echo '</pre>';

9
投票

我对@AbraCadaver的答案做了补充。我已经包含了一个javascript脚本,它将删除php启动和结束标记。我们将有更干净漂亮的转储。

也可能是这样的人。

function dd($data){
  highlight_string("<?php\n " . var_export($data, true) . "?>");
  echo '<script>document.getElementsByTagName("code")[0].getElementsByTagName("span")[1].remove() ;document.getElementsByTagName("code")[0].getElementsByTagName("span")[document.getElementsByTagName("code")[0].getElementsByTagName("span").length - 1].remove() ; </script>';
  die();
}

结果之前:

enter image description here

结果之后:

enter image description here

现在我们没有php启动和结束标记


3
投票

如果它“全部一起刷”,你可以经常试试ol'“查看源代码”。有时转储,消息和异常似乎只是一个长字符串,而事实证明换行根本不显示。特别是XML树。

或者,我曾经为此创建了一个名为InteractiveVarDump的小工具。它当然有其局限性,但有时也很方便。尽管它的设计考虑了PHP 5。


1
投票

最好的和最简单的方法来获得好的var_dump是使用xDebug(必须有任何php dev)Debian方式安装

在控制台:apt-get install php-xdebug之后你应该打开php.ini(取决于你使用的是哪个堆栈),因为它是/etc/php/7.0/fpm/php.ini

搜索display_errors

设置相同 - > display_errors = On

检查html_errors在同一档位下面,它也必须是On

保存并退出

打开/etc/php/7.0/fpm/conf.d/20-xdebug.ini

并添加到最后:````xdebug.cli_color = 1

```保存并退出。

可以在此处创建xdebug的许多其他可用选项和文档。

https://xdebug.org/docs/

祝好运并玩得开心点 !!!

Result


1
投票

你可以使用这个debugVar()而不是var_dump()

退房:https://github.com/E1NSER/php-debug-function


1
投票

这是我的函数,有一个漂亮的var_dump。与Xdebug相结合,可以更好地了解我们倾销的内容。

我改进了Xdebug的显示(给出一些空间,值之间的分隔符,包装长变量等)。

调用该函数时,可以设置标题,背景,文本颜色以区分页面中的所有var_dump。

或不 ;)

/**
 * Pretty var_dump 
 * Possibility to set a title, a background-color and a text color
 */ 
function dump($data, $title="", $background="#EEEEEE", $color="#000000"){

    //=== Style  
    echo "  
    <style>
        /* Styling pre tag */
        pre {
            padding:10px 20px;
            white-space: pre-wrap;
            white-space: -moz-pre-wrap;
            white-space: -pre-wrap;
            white-space: -o-pre-wrap;
            word-wrap: break-word;
        }

        /* ===========================
        == To use with XDEBUG 
        =========================== */
        /* Source file */
        pre small:nth-child(1) {
            font-weight: bold;
            font-size: 14px;
            color: #CC0000;
        }
        pre small:nth-child(1)::after {
            content: '';
            position: relative;
            width: 100%;
            height: 20px;
            left: 0;
            display: block;
            clear: both;
        }

        /* Separator */
        pre i::after{
            content: '';
            position: relative;
            width: 100%;
            height: 15px;
            left: 0;
            display: block;
            clear: both;
            border-bottom: 1px solid grey;
        }  
    </style>
    ";

    //=== Content            
    echo "<pre style='background:$background; color:$color; padding:10px 20px; border:2px inset $color'>";
    echo    "<h2>$title</h2>";
            var_dump($data); 
    echo "</pre>";

}

© www.soinside.com 2019 - 2024. All rights reserved.