douhuan3420 2016-09-22 14:38
浏览 50
已采纳

Foreach,for循环PHP冗余

I have the following code:

<select multiple="multiple">
    <?php $sql = "SELECT book_id, book_name FROM book ORDER BY book_name";
        try {
            $conn = new PDO("...");
            $conn->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);

            foreach ($conn->query($sql) as $row) {
                $myId   = $row['book_id'];
                $myName = $row['book_name'];
                for ($i = 0; $i < count($array); $i++) {
                    if ($myId != $array[$i]) {
                        echo("<option value='$myId'>$myName</option>");
                    }
                }
            }
        }
        catch(PDOException $e) {
        ...
        }
        $conn = null;
    ?>
</select>

My purpose is to have a selector <select>, where the not previously associated books with the user appear. In this case, the $array holds the Id of the books that are already link to this user.

I know the problem is the nested loop, because I got the result I want, eg (for a $row = 3 and a $i = 2):

Book1
Book1
Book2
Book2
Book3
Book3

And the desired result would be:

Book1
Book2
Book3

But I can't figured out how to compared the Id's, without nesting the loops.

  • 写回答

2条回答 默认 最新

  • dongtun1209 2016-09-22 14:43
    关注

    instead of your for-loop

      for ($i = 0; $i < count($array); $i++) {
                        if ($myId != $array[$i]) {
                            echo("<option value='$myId'>$myName</option>");
                        }
                    }
    

    try in_array() instad:

    if(!in_array($myId, $array)) {
        echo("<option value='$myId'>$myName</option>");
    }
    

    even if $array contains $id multiple times, this will only write once.

    edit: forgot the ! to negate. the condition.

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)

报告相同问题?

悬赏问题

  • ¥120 计算机网络的新校区组网设计
  • ¥20 完全没有学习过GAN,看了CSDN的一篇文章,里面有代码但是完全不知道如何操作
  • ¥15 使用ue5插件narrative时如何切换关卡也保存叙事任务记录
  • ¥20 海浪数据 南海地区海况数据,波浪数据
  • ¥20 软件测试决策法疑问求解答
  • ¥15 win11 23H2删除推荐的项目,支持注册表等
  • ¥15 matlab 用yalmip搭建模型,cplex求解,线性化处理的方法
  • ¥15 qt6.6.3 基于百度云的语音识别 不会改
  • ¥15 关于#目标检测#的问题:大概就是类似后台自动检测某下架商品的库存,在他监测到该商品上架并且可以购买的瞬间点击立即购买下单
  • ¥15 神经网络怎么把隐含层变量融合到损失函数中?