在 foreach 循环中,PHP 似乎在开始时读取整个数组,因此如果您突然需要将新项目附加到数组中,它们将不会被循环处理:>
On a foreach loop, it seems PHP reads the whole array at the beginning, so if you suddenly need to append new items to the array they won't get processed by the loop:
$a = array (1,2,3,4,5,6,7,8,9,10);
foreach ($a as $b)
{
echo " $b ";
if ($b ==5) $a[] = 11;
}
只打印出:1 2 3 4 5 6 7 8 9 10
只需创建一个你正在循环的数组的引用副本
Just create a reference copy of the array you are looping
$a = array(1,2,3,4,5,6,7,8,9,10);
$t = &$a; //Copy
foreach ( $t as $b ) {
echo " $b ";
if ($b == 5)
$t[] = 11;
}
或者直接使用ArrayIterator
$a = new ArrayIterator(array(1,2,3,4,5,6,7,8,9,10));
foreach ( $a as $b ) {
echo "$b ";
if ($b == 5)
$a->append(11);
}
输出
1 2 3 4 5 6 7 8 9 10 11
观看现场演示
这篇关于如何在循环遍历数组时将项目添加到数组?的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持html5模板网!
MySQLi准备好的语句&foreach 循环MySQLi prepared statement amp; foreach loop(MySQLi准备好的语句amp;foreach 循环)
mysqli_insert_id() 是从整个服务器还是从同一用户获Is mysqli_insert_id() gets record from whole server or from same user?(mysqli_insert_id() 是从整个服务器还是从同一用户获取记录?)
PHP MySQLi 无法识别登录信息PHP MySQLi doesn#39;t recognize login info(PHP MySQLi 无法识别登录信息)
mysqli_select_db() 需要 2 个参数mysqli_select_db() expects exactly 2 parameters(mysqli_select_db() 需要 2 个参数)
Php mysql pdo 查询:用查询结果填充变量Php mysql pdo query: fill up variable with query result(Php mysql pdo 查询:用查询结果填充变量)
MySQLI 28000/1045 用户“root"@“localhost"的访问MySQLI 28000/1045 Access denied for user #39;root#39;@#39;localhost#39;(MySQLI 28000/1045 用户“root@“localhost的访问被拒绝)