[英]jQuery passing an array through ajax post
我试图通过 ajax post(3 个文本字符串和 1 个多维文本字符串数组)传递 4 条数据。 当我发出 ajax 请求时,我只能检索 3 个文本字符串,而不是数组。 这是我的函数,用于容纳 ajax 请求......
function page_load(page_num, prev_page, next_page, form_arr)
{
$.ajax({
type: 'post',
cache: false,
url: 'page_content.php',
data: {'page_num' : page_num,
'prev_page': prev_page,
'next_page': next_page,
'form_arr' : form_arr
}
}).done(function(data){
$('#main_content').empty().html(data);
});
}
当函数执行时,所有数据(应该)传递给“page_content.php”,在那里我拉了 form_arr 参数(没有成功)......
<?php
//test parameter pull
echo '<pre>';
var_dump($_POST);
echo '</pre>';
?>
我看到的是这个...
array(3) {
["page_num"]=>
string(5) "start"
["prev_page"]=>
string(1) "0"
["next_page"]=>
string(1) "1"
}
我已经确认数组被正确创建并成功传递给“page_load”函数(我已经能够遍历函数内部的数组,并提醒每个字符串)。 如果我将“form_arr”变量更改为字符串,而不是函数外部的数组,则可以像其他 3 个参数一样提取它。
有什么我想念的吗?
这是我的整个js文件...
$(document).ready(function()
{
//initial page load
var page_num = 'start';
var prev_page = 0;
var next_page = 1;
var form_arr = new Array();
var form_element = new Array();
form_element['name'] = 'TAG NAME';
form_element['value'] = 'N/A';
form_arr.push(form_element);
page_load(page_num, prev_page, next_page, form_arr);
//START button click event handler
$('#main_content').delegate('a.button', 'click', function(e)
{
var btn_id = $(this).attr('href');
if(!$(this).hasClass('disabled')){
//call button_click function
button_click($(this), btn_id);
}
e.preventDefault();
});
//END button click event handler
$('#main_content').delegate('form', 'submit', function(e){
e.preventDefault();
});
//START "other" option select from dropdown
$('#main_content').delegate('select.dropdown', 'change', function(e)
{
var selected = $(this).find("option:selected");
var target = $(this).children('option.trigger').attr('class').replace('trigger ', '');
if(selected.hasClass('trigger'))
{
$('.hidden_view.' + target).show();
}else
{
$('.hidden_view.' + target).hide();
}
});
//END "other" option select from dropdown
/*** FUNCTIONS ***/
//START button_click function
function button_click(btn_obj, btn_id)
{
//set next and previous page values
var page_num = parseInt(btn_id);
var prev_page = page_num - 1;
var next_page = page_num + 1;
/* START LOOP THROUGH FORM AND PULLING VALUES */
var form = btn_obj.parent();
var form_arr = form_element_loop(form);
page_load(page_num, prev_page, next_page, form_arr);
}
//END button_click function
//START page_load function
function page_load(page_num, prev_page, next_page, form_arr)
{
var ajaxData = JSON.stringify(form_arr);
$.ajax({
type: 'post',
cache: false,
url: 'page_content.php',
data: {'page_num' : page_num,
'prev_page': prev_page,
'next_page': next_page,
'form_arr' : ajaxData}
}).done(function(data){
$('#main_content').empty().html(data);
});
}
//END page_load function
//START form_element_loop function
function form_element_loop(form)
{
var form_arr = new Array();
var x = 0;
$(form).children().each(function()
{
var element_tag = $(this).prop('tagName').toLowerCase();
if(element_tag == 'section' || element_tag == 'article' || element_tag == 'div')
{
if($(this).is(':visible'))
{
$(this).children().each(function(){
var element_tag = $(this).prop('tagName').toLowerCase();
var form_element = form_element_switch($(this));
});
}
}else
{
var form_element = form_element_switch($(this));
}
if(form_element.length > 0)
{
form_arr[x] = form_element;
}
x++;
});
return form_arr;
}
//END form_element_loop function
function form_element_switch(form_obj, form_tag)
{
var form_element = new Array();
switch(form_obj.prop('tagName').toLowerCase())
{
case 'a':
break;
case 'label':
break;
case 'input':
form_element['name'] = form_obj.attr('name');
form_element['value'] = form_obj.val();
break;
case 'select':
form_element['name'] = form_obj.attr('name');
form_element['value'] = form_obj.find(':selected').text();
break;
}
return form_element;
}
});
您无法将javascript概念发送到PHP代码。 实际上,通常,您只能将字符串从客户端发布到服务器。
最聪明的方法是将其编码为JSON:
function page_load(page_num, prev_page, next_page, form_arr)
{
$.ajax({
type: 'post',
cache: false,
url: 'page_content.php',
data: {'page_num' : page_num,
'prev_page': prev_page,
'next_page': next_page,
'form_arr' : JSON.stringify(form_arr)
}
}).done(function(data){
$('#main_content').empty().html(data);
});
}
然后将其在PHP中解码为PHP数组@
$form_arr = json_decode($_POST['form_arr'],true);
在您所提供的信息有限的情况下,我能做的最好的事情就是说您无法通过ajax发送数组。 过去,我通过调用JavaScript方法join()解决了此问题,该方法将数组转换为逗号分隔的字符串。 在后端,我将用逗号分隔的字符串转换回数组。 因此,例如,如果我想发送此数组:
var arr = ["joe,"sam","jane"];
我将在我的ajax函数中执行此操作:
$.ajax({
data:{
arr : arr.join()
}
})
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.