使用增量索引
此方法通过将整数从 0 递增到数组中的最大索引来工作。
$colors = ['red', 'yellow', 'blue', 'green'];
for ($i = 0; $i < count($colors); $i++) {
echo 'I am the color ' . $colors[$i] . '<br>';
}
这也允许以相反的顺序迭代数组而不使用 array_reverse
,如果数组很大,这可能导致开销。
$colors = ['red', 'yellow', 'blue', 'green'];
for ($i = count($colors) - 1; $i >= 0; $i--) {
echo 'I am the color ' . $colors[$i] . '<br>';
}
你可以使用此方法轻松跳过或回滚索引。
$array = ["alpha", "beta", "gamma", "delta", "epsilon"];
for ($i = 0; $i < count($array); $i++) {
echo $array[$i], PHP_EOL;
if ($array[$i] === "gamma") {
$array[$i] = "zeta";
$i -= 2;
} elseif ($array[$i] === "zeta") {
$i++;
}
}
输出:
alpha
beta
gamma
beta
zeta
epsilon
对于没有增量索引的数组(包括索引顺序相反的数组,例如 [1 => "foo", 0 => "bar"]
,["foo" => "f", "bar" => "b"]
),这不能直接完成。可以使用 array_values
或 array_keys
代替:
$array = ["a" => "alpha", "b" => "beta", "c" => "gamma", "d" => "delta"];
$keys = array_keys($array);
for ($i = 0; $i < count($array); $i++) {
$key = $keys[$i];
$value = $array[$key];
echo "$value is $key\n";
}