Эта foreachконструкция обеспечивает простой способ перебора массивов. foreachработает только с массивами и объектами и выдает ошибку, когда вы пытаетесь использовать его для переменной с другим типом данных или неинициализированной переменной. Есть два синтаксиса:

foreach (iterable_expression как $value)    утверждение foreach (iterable_expression as $key => $value)    утверждение

Первая форма проходит через итерацию, заданную iterable_expression. На каждой итерации значение текущего элемента присваивается $value.

Вторая форма будет дополнительно назначать ключ текущего элемента $keyпеременной на каждой итерации.

Обратите внимание, что foreachэто не изменяет внутренний указатель массива, который используется такими функциями, как current() и key() .

Можно настроить итерацию объекта .

Чтобы иметь возможность напрямую изменять элементы массива в цикле, поставьте перед ним $value&. В этом случае значение будет присвоено по ссылке .

<?php
$arr = array(1, 2, 3, 4);
foreach ($arr as &$value) {
    $value = $value * 2;
}
// $arr is now array(2, 4, 6, 8)
unset($value); // break the reference with the last element
?>

Предупреждение

Ссылка на a $valueи последний элемент массива остаются даже после завершения foreachцикла. Рекомендуется уничтожить его с помощью unset() . В противном случае вы столкнетесь со следующим поведением:

<?php
$arr = array(1, 2, 3, 4);
foreach ($arr as &$value) {
    $value = $value * 2;
}
// $arr is now array(2, 4, 6, 8)

// without an unset($value), $value is still a reference to the last item: $arr[3]

foreach ($arr as $key => $value) {
    // $arr[3] will be updated with each value from $arr...
    echo "{$key} => {$value} ";
    print_r($arr);
}
// ...until ultimately the second-to-last value is copied onto the last value

// output:
// 0 => 2 Array ( [0] => 2, [1] => 4, [2] => 6, [3] => 2 )
// 1 => 4 Array ( [0] => 2, [1] => 4, [2] => 6, [3] => 4 )
// 2 => 6 Array ( [0] => 2, [1] => 4, [2] => 6, [3] => 6 )
// 3 => 6 Array ( [0] => 2, [1] => 4, [2] => 6, [3] => 6 )
?>

Можно выполнить итерацию значения константного массива по ссылке:

<?php
foreach (array(1, 2, 3, 4) as &$value) {
    $value = $value * 2;
}
?>

 

Примечание :

foreachне поддерживает возможность подавления сообщений об ошибках с помощью @.

Еще несколько примеров для демонстрации использования:

<?php
/* foreach example 1: value only */

$a = array(1, 2, 3, 17);

foreach ($a as $v) {
    echo "Current value of \$a: $v.\n";
}

/* foreach example 2: value (with its manual access notation printed for illustration) */

$a = array(1, 2, 3, 17);

$i = 0; /* for illustrative purposes only */

foreach ($a as $v) {
    echo "\$a[$i] => $v.\n";
    $i++;
}

/* foreach example 3: key and value */

$a = array(
    "one" => 1,
    "two" => 2,
    "three" => 3,
    "seventeen" => 17
);

foreach ($a as $k => $v) {
    echo "\$a[$k] => $v.\n";
}

/* foreach example 4: multi-dimensional arrays */
$a = array();
$a[0][0] = "a";
$a[0][1] = "b";
$a[1][0] = "y";
$a[1][1] = "z";

foreach ($a as $v1) {
    foreach ($v1 as $v2) {
        echo "$v2\n";
    }
}

/* foreach example 5: dynamic arrays */

foreach (array(1, 2, 3, 4, 5) as $v) {
    echo "$v\n";
}
?>

Распаковка вложенных массивов с помощью list()

(PHP 5 >= 5.5.0, PHP 7, PHP 8)

Можно выполнить итерацию по массиву массивов и распаковать вложенный массив в переменные цикла, указав list() в качестве значения.

Например:

<?php
$array = [
    [1, 2],
    [3, 4],
];

foreach ($array as list($a, $b)) {
    // $a contains the first element of the nested array,
    // and $b contains the second element.
    echo "A: $a; B: $b\n";
}
?>

Приведенный выше пример выведет:

А: 1; БИ 2
А: 3; Б: 4

Вы можете указать меньше элементов в list() , чем во вложенном массиве, и в этом случае оставшиеся значения массива будут проигнорированы:

<?php
$array = [
    [1, 2],
    [3, 4],
];

foreach ($array as list($a)) {
    // Note that there is no $b here.
    echo "$a\n";
}
?>

Приведенный выше пример выведет:

1
3

Уведомление будет сгенерировано, если элементов массива недостаточно для заполнения list() :

<?php
$array = [
    [1, 2],
    [3, 4],
];

foreach ($array as list($a, $b, $c)) {
    echo "A: $a; B: $b; C: $c\n";
}
?>

Приведенный выше пример выведет:

Примечание: Неопределенное смещение: 2 в example.php в строке 7
А: 1; БИ 2; С:

Примечание: Неопределенное смещение: 2 в example.php в строке 7
А: 3; Б: 4; С: