是否可以通过单个 AJAX 请求发送表单元素(使用方法序列化)和其他参数?.serialize()
例子:
$.ajax({
type : 'POST',
url : 'url',
data : {
$('#form').serialize(),
par1 : 1,
par2 : '2',
par3: 232
}
}
如果不是,将表单与其他参数一起提交的最佳方式是什么?
谢谢
是否可以通过单个 AJAX 请求发送表单元素(使用方法序列化)和其他参数?.serialize()
例子:
$.ajax({
type : 'POST',
url : 'url',
data : {
$('#form').serialize(),
par1 : 1,
par2 : '2',
par3: 232
}
}
如果不是,将表单与其他参数一起提交的最佳方式是什么?
谢谢
serialize()
有效地将表单值转换为有效的查询字符串,因此您可以简单地附加到字符串:
$.ajax({
type : 'POST',
url : 'url',
data : $('#form').serialize() + "&par1=1&par2=2&par3=232"
}
或者,如果您将参数存储在某个对象变量中,则可以使用form.serialize()
with 。$.param(object)
用法是:
var data = form.serialize() + '&' + $.param(object)
请参阅http://api.jquery.com/jQuery.param以获取更多参考。
我不知道,但上述方法都不适合我,然后我使用了它并且它有效:
在表单的序列化数组中,它存储为键值对
我们将一个或多个新值推送到表单变量中,然后我们现在可以直接传递这个变量。
var form = $('form.sigPad').serializeArray();
var uniquekey = {
name: "uniquekey",
value: $('#UniqueKey').val()
};
form.push(uniquekey);
如果您想使用表单序列化发送数据,您可以试试这个
var form= $("#formId");
$.ajax({
type: form.attr('method'),
url: form.attr('action'),
data: form.serialize()+"&variable="+otherData,
success: function (data) {
var result=data;
$('#result').attr("value",result);
}
});
像这样传递参数的值
data : $('#form_id').serialize() + "¶meter1=value1¶meter2=value2"
等等。
按照Rory McCrossan 的回答,如果您想发送一个整数数组(几乎适用于 .NET),代码如下:
// ...
url: "MyUrl", // For example --> @Url.Action("Method", "Controller")
method: "post",
traditional: true,
data:
$('#myForm').serialize() +
"¶m1="xxx" +
"¶m2="33" +
"&" + $.param({ paramArray: ["1","2","3"]}, true)
,
// ...
在 js 中编码:
var temp = $("#pay_property_amount").serialize();
temp = btoa(temp);
并传入 ajax
data: { temp_data : temp },
用php解码
$temp_data = base64_decode($this->input->post('temp_data'));
if($temp_data){
$temp_data = $this->unserializeForm($temp_data);
}
function unserializeForm($str) {
$returndata = array();
$strArray = explode("&", $str);
$i = 0;
foreach ($strArray as $item) {
$array = explode("=", $item);
if (preg_match('/(%5B%5D)/', $array[0])) {
$array[0] = str_replace('%5B%5D','',$array[0]);
if(array_key_exists($array[0],$returndata)){
$returndata[$array[0]][]=$array[1];
}else{
$returndata[$array[0]] =array();
$returndata[$array[0]][]=$array[1];
}
}else
{
$returndata[$array[0]] = $array[1];
}
}
return $returndata;
}
$("#add_form").submit(function(e) {
e.preventDefault();
var total_qty = $('#total_qty').text();
var total_amt = $('#total_amt').text();
$("#add_btn").val('adding....');
$.ajax({
url: 'action.php',
method: 'post',
data: $(this).serialize() + "&total_qty="+total_qty + "&total_amt="+total_amt,
success: function(data){
console.log(data);
}
});
});
你也可以使用 serializeArray 函数来做同样的事情。
您可以使用带有另一个表单内容的 jQuery 创建一个辅助表单,然后从其他参数中添加该表单,因此您只需在 ajax 调用中对其进行序列化。
function createInput(name,value){
return $('<input>').attr({
name: name,
value: value
});
}
$form = $("<form></form>");
$form.append($("#your_form input").clone());
$form.append(createInput('input_name', 'input_value'));
$form.append(createInput('input_name_2', 'input_value_2'));
....
$.ajax({
type : 'POST',
url : 'url',
data : $form.serialize()
}
我用under语句解决了这个问题;使用 url 相同的 GET 方法发送数据
$.ajax({
url: 'includes/get_ajax_function.php?value=jack&id='+id,
type: 'post',
data: $('#b-info1').serializeArray(),
并通过$_REQUEST['value']
OR获得价值$_GET['id']