我想在循环中使用一个函数,以便将我的数据以漂亮的格式打印到我的表格中。
$pdo = Database::connect();
$sql = 'SELECT * FROM data ORDER BY id ASC';
foreach ($pdo->query($sql) as $row) {
function formatSizeUnits($bytes)
{
if ($bytes >= 1073741824) {
$bytes = number_format($bytes / 1073741824, 2).' GB';
} elseif ($bytes >= 1048576) {
$bytes = number_format($bytes / 1048576, 2).' MB';
} else {
$bytes = '0 bytes';
}
return $bytes;
}
$bytes = $row['fileSize'];
formatSizeUnits($bytes);
echo('<td>'.$bytes.'</td>');
}
但现在我只得到数据库表的第一个条目。我怎样才能完成这项工作?
答案 0 :(得分:3)
使用和声明你的功能是两回事。您只需要声明一次您的功能。它会抛出一个错误,因为它试图在下一个循环中重新声明它。
像这样:
$pdo = Database::connect();
$sql = 'SELECT * FROM data ORDER BY id ASC';
foreach ($pdo->query($sql) as $row) {
$bytes = $row['fileSize'];
formatSizeUnits($bytes);
echo('<td>'.$bytes.'</td>');
}
function formatSizeUnits($bytes)
{
if ($bytes >= 1073741824) {
$bytes = number_format($bytes / 1073741824, 2).' GB';
} elseif ($bytes >= 1048576) {
$bytes = number_format($bytes / 1048576, 2).' MB';
} else {
$bytes = '0 bytes';
}
return $bytes;
}
还有关于你的问题:
您没有通过引用将$ bytes传递给formatSizeUnits()
,但是它返回了值,您需要覆盖它。
$bytes = formatSizeUnit($bytes);
答案 1 :(得分:0)
你不能在循环中声明一个函数。而是在循环中使用它在循环外定义它并仅在循环中调用一次