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