使用增量索引

此方法通过将整数从 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_valuesarray_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";
}