我正在使用 cakephp 表单创建表单。它正在创建这样的形式:
<form name='license' action='/some/action' action='POST'>
<input type="text" id="license0Number" name="data[license][0][number]">
<input type="text" id="license0Year" name="data[license][0][year]">
<input type="text" id="license1Number" name="data[license][1][number]">
<input type="text" id="license1Year" name="data[license][1][year]">
</form>
以正常形式提交表单并获取如下数据时工作正常:
$data = array( 'license' => array( '0' => array( 'number'=>'123', 'year'=>'2000' ),
'1' => array( 'number'=>'321', 'year'=>'2003' )
);
但是当我使用 jQuery $.ajax()
函数提交相同的表单并使用 serialize()
函数发布数据时。我在服务器端获取类似这样的数据。
Array
(
[data%5Blicense%5D%5B0%5D%5Bnumber%5D] => 123
[data%5Blicense%5D%5B0%5D%5Byear%5D] => 2000
[data%5Blicense%5D%5B1%5D%5Bnumber%5D] => 321
[data%5Blicense%5D%5B1%5D%5Byear%5D] => 2003
)
使用 jQuery $.ajax() 函数时如何以关联数组的形式获取表单数据?
编辑:
$('#license_form').live( 'submit', function( event ) {
var action = '/some/action';
var data = $(this).serialize();
$.ajax({
type: "POST",
url: action,
data: data, // form data
success: function( result ) { alert( result ); },
error: function() { alert('error'); }
});
event.preventDefault();
});
谢谢
最佳答案
无需使用低级 ajax,请使用 $.post 简写。
试试这个:
$(function(){
$("#submit").click(function(){
//Since you're talking about POST
$.post('path_to_php_script.php', {
"license0Number" : $("#license0Number").val(),
"license0Year" : $("#license0Year").val(),
"license1Number" : $("#license1Number").val(),
"license1Year" : $("#license1Year").val()
}, function(respond){
//Respond from PHP
//Maybe replace some div with the server respond?
$("#some_div").html(respond); //optional
});
});
});
您要求使用 jquery 进行 POST ASSOC ARRAY, 所以你会明白的,
在你的 php 脚本中:
<?php
print_r($_POST); //will print what you want
关于php - 使用 jquery ajax 发布关联数组,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/12247457/