我有一个数组,其中包含特定文章 ($link_cat) 的类别。然后,我使用 mysql_fetch_array 将所有可用的类别打印到带有复选框的列表中。在执行此操作时,我希望它将其所在的值与另一个数组中的值进行比较。如果匹配,则表示其中一个类别适用于这篇文章,它应该打印出一行代码来应用选中的属性。伟大的!除了它不工作=[
while ( $row = mysqli_fetch_array($results, MYSQLI_ASSOC) ){
$cat[$i] = $row['category'];
$cat_id[$i] = $row['cat_id'];
echo '<li><input type="checkbox" ';
$catCount = count($link_cat);
for ($ct = 0; $ct < $catCount; $ct++){
if ($cat_id[$i] == $link_cat[$ct]){
echo 'checked="checked" ';
}
}
echo 'name="' . $cat_id[$i] . '" />' . $cat[$i] . '</li>';
$i++;
}
我以前从未真正做过嵌套循环(我怀疑这就是问题所在)。
问题似乎是,当它运行时, $link_cat[0] 将在其中检查第一个类别 - 没有注册。它出现空白。在 for 循环中打印出变量证实了这一点。任何其他 [1] [2] 等都可以。它只是 [0]。但为什么?这似乎没有任何意义。我知道里面有东西,因为我在填充数组时打印了它的内容,只是为了检查。然而,它不仅仅在循环期间显示。有任何想法吗?