0

我有一个带有一些 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"]未设置,如果有错字,它会抱怨。

4

1 回答 1

2

您可以尝试 .val() 而不是 .text()

于 2013-02-23T15:09:26.190 回答