我有一个带有一些 jQuery UI 可排序的表单,这些表单的data-属性被序列化到隐藏的文本框中,所以当我发送表单时,我的 PHP 脚本可以查看$_POST["contents"](这是一个像这样的字符串1-2-2-1)的值并将其传递给我的 MySQL更新查询。问题是,在发送表单(来自 javascript)之前,文本框的报告值与$_POST.
表格:
<form method="post" action="?update">
    <input type="text" name="id" style="display:none" value="1" />
    <input type="text" name="path" placeholder="Endereço Ex.: /pacotes/pureenergy" value="/some/path" /> <input type="text" name="title" placeholder="Título da página" value="<?php echo $t;?>" /><br />
    <!-- Some stuff hidden for briefness -->
    <input type="text" id="ci" name="contents" style="display:none" value="1-2-2-1" />
    <input type="submit" value="Atualizar página" onclick="updateForm()">
</form>
Javascript:
function updateForm() {
    var txt = $("#dropzone li:first-of-type").data("id");
    $("#dropzone li:not(:first-of-type)").each(function() {
        txt = txt+"-"+$(this).data("id");
    });
    $("#ci").text(txt);
    alert(txt);
}
PHP:
$id = $_POST["id"];
$p = $_POST["path"];
$t = $_POST["title"];
$c = $_POST["contents"];
mysql_query("UPDATE aruna.pages SET path='$p', title='$t', contents='$c' WHERE id=$id") or die(mysql_error());
javascript 报告的值alert()符合预期,但是当我发送表单时, 的值$_POST["contents"]与 HTML 中硬编码的值相同。
编辑: PHP 不会抱怨$_POST["contents"]未设置,如果有错字,它会抱怨。