0

有人可以指出为什么以下不起作用?即使我选择不同的单选按钮,它也只会重定向到第一个位置。

PHP:

if (isset($_POST['submit'])) {

    if (!empty($_POST['electronics'])) {

        if ($_POST['electronics'] = "camera") {
            header("location: camera.php");
            exit();
        }
        if ($_POST['electronics'] = "cell") {
            header("location: cellphones.php");
            exit();
        }
        if ($_POST['electronics'] = "cable") {
            header("location: cables.php");
            exit();
        }
        if ($_POST['electronics'] = "tv") {
            header("location: tv.php");
            exit();
        }
    }

...

HTML:

<form action="" method="post">
    <input type="radio"  name="electronics" value="cell"/>
    <input type="radio"  name="electronics" value="camera"/>
    <input type="radio"  name="electronics" value="cable"/>
    <input type="radio"  name="electronics" value="tv"/>
    <input type="submit" name="submit">
</form>
4

3 回答 3

5

您必须使用比较运算符==而不是=

if (isset($_POST['submit'])) {

    if (!empty($_POST['electronics'])) {

        if ($_POST['electronics'] == "camera") {
            header("location: camera.php");
        }
        else if ($_POST['electronics'] == "cell") {
            header("location: cellphones.php");
        }
        else if ($_POST['electronics'] == "cable") {
            header("location: cables.php");
        }
        else if ($_POST['electronics'] == "tv") {
            header("location: tv.php");
        }
    }

...

此外,这exit()也是多余的,因为您已经重定向到另一个页面。

于 2013-09-12T02:39:41.837 回答
2

=是赋值。==是平等。你把两者混淆了。

于 2013-09-12T02:39:43.703 回答
1

要添加到其他答案,当您使用赋值运算符 (=) 而不是比较运算符 (== 或 ===) 时,赋值是从右到左传递的。

所以以下是正确的:

"camera" == $_POST['electronics'] = "camera"

在您的情况下,这足以满足if

这与让您使用一个值进行多个分配的行为相同。

例如:

$foo = $bar = 10;

$foo并且$bar都分配了10。

于 2013-09-12T02:45:17.257 回答