if/elseif/else 只返回第一个条件

if/elseif/else only returning first condition

我在以下 if/elseif/else 语句中遇到了 2 个问题:

$rows = array();
$stmt = $dbconnection->query("SELECT * FROM TABLE_NAME WHERE data_field LIKE 'data_selection'");
if ($stmt) {
    while ($row = $stmt->fetch(PDO::FETCH_ASSOC)) {
        array_push($rows, $row);

        if ($row['something '] == 'selection1') {
            $highlightsarray = array("gridHighlights" => 'text option 1 to display on site');
            $highlights = $row + $highlightsarray;
                } elseif ($row['something'] == 'selection2') {
            $highlightsarray = array("gridHighlights" => 'text option 2 to display on site');
            $highlights = $row + $highlightsarray;
                } else {
            $highlights = "<p>default messaging</p>";
        }
        $fields = $highlights; // this is a placeholder for other if statements I need to add
        $output .= $modx->getChunk('chunk_name', $fields);

    }
}
return $output;
}

我遇到的第一个问题是 == 没有返回任何结果,如果我将其更改为 = 则它会起作用。

如果我声明 ($row['something '] = 'selection1')(只有 =),那么它只会返回第一个 if 条件,即使它不是真的并且应该返回elseifelse 条件。

不确定我在这里做错了什么,非常感谢任何帮助,谢谢。

关闭这个问题,按照建议做 var_dump 并检查我的字符串使这个工作正常。这是最终使用的代码:

$rows = array();
$stmt = $dbconnection->query("SELECT * FROM TABLE_NAME WHERE data_field LIKE 'data_selection'");
if ($stmt) {
while ($row = $stmt->fetch(PDO::FETCH_ASSOC)) {
    array_push($rows, $row);

var_dump($row); // to review output

    if ($row['something '] == NULL) {
        $highlights = $row;
            } elseif ($row['something'] == 'selection2') {
        $highlightsarray = array("gridHighlights" => 'text option 2 to display on site');
        $highlights = $row + $highlightsarray;
            } elseif ($row['something'] == 'selection1') {
        $highlightsarray = array("gridHighlights" => 'text option 1 to display on site');
        $highlights = $row + $highlightsarray;
    }
    $fields = $highlights; // this is a placeholder for other if statements I need to add (like $fields = $highlights + $anotherIfStatement;)
    $output .= $modx->getChunk('chunk_name', $fields);

}
}
return $output;
}