在 PHP 中漂亮地打印 JSON
本文将介绍在 PHP 中美化原始 JSON 字符串的不同方法。
使用 HTML <pre>
标签和 JSON_PRETTY_PRINT
选项来美化 PHP 中的 JSON 字符串
我们可以使用 json_encode()
函数将值转换为 JSON 格式。我们可以将索引数组、关联数组和对象编码为 JSON 格式。json_encode()
函数有一个选项 JSON_PRETTY_PRINT
美化 JSON 字符串。我们可以指定要美化的字符串,然后是 json_encode()
函数中的选项。它将在字符之间添加一些空格并使字符串看起来更好。但是,我们可以使用 <pre>
HTML 标签将字符串缩进到新行。我们将在下面的例子中美化一个关联数组。标签在字符串中的每个键值对之后保留换行符。
例如,在变量 $age
中创建一个关联数组。写出键 Marcus
、Mason
和 Jadon
以及值 23
、19
和 20
。接下来,在 $age
变量上使用 json_encode()
函数并编写选项 JSON_PRETTY_PRINT
作为第二个参数,并将表达式存储在 $json_pretty
变量中。然后,用 HTML <pre>
标签回显包含它的变量。
示例代码:
$age = array("Marcus"=>23, "Mason"=>19, "Jadon"=>20)
$json_pretty = json_encode($age, JSON_PRETTY_PRINT);
echo "<pre>".$json_pretty."<pre/>";
输出:
{
"Marcus": 23,
"Mason": 19,
"Jadon": 20
}
使用 application/json
和 JSON_PRETTY_PRINT
选项来美化 PHP 中的 JSON 字符串
我们可以使用 header()
函数将 Content-Type
设置为 application/json
以通知浏览器类型。它将以 JSON 格式显示数据。我们可以像第一种方法一样使用 JSON_PRETTY_PRINT
选项来美化字符串。我们将使用相同的关联数组进行演示。我们可以像第一种方法一样使用 json_encode()
函数。
例如,编写 header()
函数并将 Content-Type
设置为 application/json
。在下一行中,像我们在第一种方法中所做的那样,在数组上使用带有 JSON_PRETTY_PRINT
选项的 json_encode()
函数。因此,我们将在每一行中获得一个 JSON 数据的美化版本。
示例代码:
$age = array("Marcus"=>23, "Mason"=>19, "Jadon"=>20);
header('Content-Type: application/json');
echo json_encode($age, JSON_PRETTY_PRINT);
?>
输出:
{
"Marcus": 23,
"Mason": 19,
"Jadon": 20
}
在 PHP 中使用 json_encode()
和 json_decode()
函数美化 JSON 字符串
我们可以使用 json_encode()
函数、json_decode()
函数和 JSON_PRETTY_PRINT
作为参数来美化 PHP 中的 JSON 字符串。我们也像第二种方法一样使用 header()
函数来通知浏览器有关 JSON 格式的信息。我们将在以下示例中美化一个 JSON 对象。我们将获取 JSON 对象并使用 json_decode()
函数对其进行解码,然后使用 json_encode()
函数和 JSON_PRETTY_PRINT
选项对其进行编码。
例如,将 Content-Type
设置为 application/json
,就像我们在上面的方法中所做的那样。创建一个变量 $json1
并在其中存储一个原始 JSON 对象。然后,对变量 $json1
使用 json_decode()
函数。使用解码的 JSON 对象作为 json_encode()
函数的第一个参数,使用 JSON_PRETTY_PRINT
选项作为第二个参数。将表达式存储在 $json2
变量中并回显它。
示例代码:
header('Content-Type: application/json');
$json1 = '{"a":10,"b":20,"c":30,"d":40,"e":50}';
$json2 = json_encode(json_decode($json1), JSON_PRETTY_PRINT);
echo $json2;
输出:
{
"a": 10,
"b": 20,
"c": 30,
"d": 40,
"e": 50
}
免责声明:
① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。
② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341