我想使用AJAX将表单输入从页面发送到PHP函数,并将数据保存在多维数组中。应该没有页面重新加载,响应可以是简单的true
或false
。在Chrome浏览器中,我可以在JSON中的“Request Payload”元素中看到两个输入,但是如何在PHP中检索数据并将此数据转换为数组?
HTML:
<div id="formEditBilling"><form>
<input name="register[personal][firstname]" type="text" id="firstname" value="" class="text required " placeholder="Firstname">
<input name="register[personal][lastname]" type="text" id="lastname" value="" class="text required " placeholder="Lastname">
<input type="buttom" id="editBilling" value="speichern"/></form></div>
JavaScript的:
<script type="text/javascript">
$('#editBilling').click(function() {
editBilling();
});
function editBilling(){
var url = '/checkout/saveAddress'; // Server Function
var data = $('#formEditBilling form').serializeArray();
data = JSON.stringify(data);
$.ajax({
'type': 'post',
'async': false,
'data': data,
'url': url,
'contentType': "application/json",
'dataType': "text",
'success': function (result, data) {
$('.output').html(data); // Output Div
}
});
}
</script>
这是我的问题。我怎样才能获得如下数组:
['register'] => Array
(
['personal'] => Array
(
['firstname'] => "Michael"
['lastname'] => "Cooper"
)
PHP:这是我的尝试,但它不起作用,$_POST
似乎是空的。
public function saveAddressAction(){
$data = json_decode(stripslashes($_POST['register']));
return true;
}
答案 0 :(得分:1)
您的功能括号未正确连接,请尝试使用此
function editBilling(){
var url = '/checkout/saveAddress'; // Server Function
var data = $('#formEditBilling form').serializeArray();
data = JSON.stringify(data);
$.ajax({
'type': 'post',
'async': false,
'data': data,
'url': url,
'contentType': "application/json",
'dataType': "text",
'success': function (result, data) {
$('.output').html(data); // Output Div
}
});
}
答案 1 :(得分:1)
您需要将序列化的formdata转换为正确的JSON
var formdata = $('#formEditBilling form').serializeArray();
var formobject = {};
$(formdata).each(function (e) {
formobject[formdata[e].name] = formdata[e].value;
});
var data = {
action: action,
json: JSON.stringify(formobject)
};
使用ajax发送
function send(data) {
var deferred = $.ajax({
method: "post",
url: settings.ajaxURL,
dataType: "json",
data: data
});
return deferred.promise();
}
send(formdata).done(function(response){
console.log(response)
}
抓住PHP
$_POST['action']
json_decode($_POST['json']);