我有这个PHP脚本:
function hoeveelzijner ($jaar, $id)
{
function hoeveelhoeveel($beginstamp, $endstamp, $id)
{
$dates = mysql_query('SELECT v_date FROM visitors WHERE id="'.$id.'" AND v_date<"'.$endstamp.'" AND v_date>"'.$beginstamp.'"');
return mysql_num_rows($dates);
}
$i = 1;
while ($i < 13)
{
$hoeveel[$i-1] = hoeveelhoeveel(mktime(0, 0, 0, $i, 1, $jaar),mktime(0, 0, 0, $i, cal_days_in_month(CAL_GREGORIAN,$i,$jaar),$jaar),$id);
$i = $i+1;
}
return $hoeveel;
}
当我把它放在它下面时,它可以正常工作:
$values = hoeveelzijner(2005, 1);
但是,当我这样做两次时,例如:
$values = hoeveelzijner(2005, 1);
$test = hoeveelzijner(2000, 4);
我收到此错误:致命错误:无法重新声明hoeveelhoeveel()(之前在......中声明:69)在第69行......
任何人都知道我做错了什么?如果我只能使用它一次就有点破坏了使用函数的目的......
额外信息:我不包含任何其他文件,也不会在脚本中的其他位置重新声明该函数。
非常感谢!
答案 0 :(得分:15)
您不仅可以使用一次;你只能声明一次。每次使用函数hoeveelzijner
时,都会声明函数hoeveelhoeveel
。如果你多次调用它,你将重新声明它,这是禁止的。
您有两个选择:第一个是将函数定义放在包含函数之外。该函数将在首次解析文件时声明,然后重复使用。如果要将函数定义限制在特定范围内(原则上是个好主意),可以使用PHP 5.3中引入的匿名函数语法:
function hoeveelzigner($jaar, $id)
{
$hoeveelhoeveel = function($beginstamp, $endstamp, $id)
{
$dates = mysql_query('SELECT v_date FROM visitors WHERE id="'.$id.'" AND v_date<"'.$endstamp.'" AND v_date>"'.$beginstamp.'"');
return mysql_num_rows($dates);
};
// etc
}
然后,您可以将该功能用作$hoeveelhoeveel(...)
。
答案 1 :(得分:0)
尽管PHP允许你在任何地方声明一个函数,但我认为你所做的事情并不是最佳实践。
对大多数人来说,这看起来不错。
您应该在父函数之外声明该函数。
或者你可以在内部函数周围添加function_exists()
,尽管我只是在父函数之外声明内部函数。
甚至可能为它上课。
答案 2 :(得分:0)
您不能再次声明它,特别是如果函数多次调用它。这是一个应该有效的简单改变。
function hoeveelhoeveel($beginstamp, $endstamp, $id)
$dates = mysql_query('SELECT v_date FROM visitors WHERE id="'.$id.'" AND v_date<"'.$endstamp.'" AND v_date>"'.$beginstamp.'"');
return mysql_num_rows($dates);
}
function hoeveelzijner ($jaar, $id)
{
$i = 1;
while ($i < 13)
{
$hoeveel[$i-1] = hoeveelhoeveel(mktime(0, 0, 0, $i, 1, $jaar),mktime(0, 0, 0, $i, cal_days_in_month(CAL_GREGORIAN,$i,$jaar),$jaar),$id);
$i = $i+1;
}
return $hoeveel;
}
然后你可以在其他函数中以类似的方式调用任一函数,如果需要的话。