php - 单击提交按钮时隐藏隐藏的输入值 (php/jquery)

标签 php javascript jquery hidden-field

好的,所以我的问题是:

我有一个表格,要求输入名字、姓氏和城市。用户点击提交,然后信息显示到这个表中:

<p>You entered the following data:</p>

            <form action="1.php" method="post">

                <input type="hidden" name="action" value="update">
                <input type="hidden" name="city" value="<?php echo $user->get_city(); ?>">

                <table>
                    <tr>
                        <th>First Name:</th>
                        <td><?php echo $user->get_fname(); ?></td>
                        <td><input type="button" id="edit_fname" value="Edit"></td>
                        <td><input type="text" id="fname" name="fname" size="20"></td>
                        <td><input type="hidden" id="valf" name="val" value="fname">
                            <input type="hidden" id="lnf" name="lname" value="<?php echo $user->get_lname(); ?>">
                            <input type="submit" id="subfn" value="Submit"></td>
                    </tr>
                    <tr>
                        <th>Last Name:</th>
                        <td><?php echo $user->get_lname(); ?></td>
                        <td><input type="button" id="edit_lname" value="Edit"></td>
                        <td><input type="text" id="lname" name="lname" size="20"></td>
                        <td><input type="hidden" id="vall" name="val" value="lname">
                            <input type="hidden" id="fnf" name="fname" value="<?php echo $user->get_fname(); ?>">
                            <input type="submit" id="subln" value="Submit"></td>
                    </tr>
                    <tr>
                        <th align="right">City:</th>
                        <td><?php echo $user->get_city(); ?></td>
                        <td>&nbsp;</td>
                    </tr>
                </table>
            </form>

因此,当用户单击编辑按钮时,会显示一个文本框和一个提交按钮,并且根据它是名字编辑还是姓氏编辑,我有适当的隐藏值与表单一起发送。唯一的问题是,无论如何,即使您单击名字字段的提交按钮,隐藏的输入“val”也会设置为“lname”。

这里是 jquery:

$().ready = function() {
                    $('#fname').hide();
                    $('#lname').hide();
                    $('#subfn').hide();     // submit button for first name
                    $('#subln').hide();     // submit button for last name
                    $('#valf').hide();      // hidden value for fname so we know to post lname
                    $('#vall').hide();      // hidden value for lname so we know to post fname
                    $('#lnf').hide();       // hidden value to post last name when first name edit submit
                    $('#fnf').hide();       // hidden value to post first name when last name edit submit

                    $("#edit_fname").click(function() {
                        $('#fname').show();
                        $('#subfn').show();
                        $('#valf').show();
                        $('#lnf').show();

                        if ($('#lname').show) {     // if last name edit is showing, hide it
                            $('#lname').hide();
                            $('#subln').hide();
                            $('#vall').hide();
                            $('#fnf').hide();

                        }
                    });

                    $("#edit_lname").click(function() {
                        $('#lname').show();
                        $('#subln').show();
                        $('#vall').show();
                        $('#fnf').show();

                        if ($('#fname').show()) {       // if first name edit is showing, hide it
                            $('#fname').hide();
                            $('#subfn').hide();
                            $('#valf').hide();
                            $('#lnf').hide();
                        }
                    });

                }();

下面是单击“提交”按钮并将“操作”更改为“更新”时的 PHP:

case 'update':
        $val = $_POST['val'];

        if ($val == 'fname') {
            $fname = $_POST['fname'];
            $lname = $_POST['lname'];
            $city = $_POST['city'];

            $user = new User($fname, $lname, $city);
            break;
        }
         else if ($val == 'lname') {
            $fname = $_POST['fname'];
            $lname = $_POST['lname'];
            $city = $_POST['city'];

            $user = new User($fname, $lname, $city);
            break;
        }

我测试过 $val 是什么,它似乎无论如何都卡在 'lname' 上。所以,我认为我的 jQuery 代码有问题,或者问题是无论如何都会发送姓氏“val”值,这不应该是因为我有它的 ID,当单击名字按钮。

这都是帮助我学习 OOP 的实验。显然这根本不是生产代码。我目前是应用科学副学士学位的一年级学生,还有很多年才能获得计算机科学学士学位。这甚至不是类(class)的一部分……我只是觉得无聊,但真的很喜欢编程。

所以,认为有人可以提供帮助吗?抱歉发了这么长的帖子!

最佳答案

这就是为什么。看下面两行代码

<td><input type="hidden" id="valf" name="val" value="fname">

.....

<td><input type="hidden" id="vall" name="val" value="lname">

它们定义了一个名为val 的隐藏字段,首先使用值fname,然后使用值lname。即使你给他们不同的 ID,他们的名字仍然是一样的。在您的 jquery 代码中,您不会更改 val 的值,这就是为什么它始终保持 lname 的原因。

您必须根据您在某处的逻辑更改该值。您可以使用以下 jQuery 选择器

$("input[type='hidden'][name='val']")

编辑

所以不是这个

$('#valf').show();

你可以写

$("input[type='hidden'][name='val']").val("fname");

而不是这个

$('#vall').show();

你可以写

$("input[type='hidden'][name='val']").val("lname");

关于php - 单击提交按钮时隐藏隐藏的输入值 (php/jquery),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/14515932/

相关文章:

php - 在 MYSQL 和 PHP 中显示值直到第一个空格

php - 获取 PHP 中作为参数传递的常量名称

php - 如果数组为空,则跳过 foreach 的最干净方法

javascript - 如何在悬停状态下使用 jQuery 更改按钮的内容/值

javascript - 使用 JS 在 Google Analytic 中设置目标

php - 无法使用ajax将变量发送到php

javascript - Backbone 发送请求负载而不是 FormData

javascript - 页面将#link 添加到元素错误

javascript - 如何使用 Angular 服务功能?它抛出错误 :"Cannot read property of undefined"

jQuery 无法使 .click 处理此代码