- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在尝试使用ajax发送带有序列化表单数据的对象数组。当我发送序列化数据并将数组添加到 ajax 数据时,问题就出现了。序列化的表单数据不会以正确的格式到达 Controller 。这是我的 ajax:
$('body').on('submit','#RequestPakagesTempAddForm', function(e){
if (!(productArray.length > 0) || jQuery.isEmptyObject(productArray) ) {
alert("Falta agregar productos");
return false;
}
form = $("#RequestPakagesTempAddForm").serialize();
$.ajax({
type: "POST",
url: $(this).attr('action'),
data: {
'formData': form,
'productArray': productArray
},
success: function(data){
/*$('.modal').modal('hide');
$(".success").fadeIn(500).delay(2000).fadeOut(500);*/
$("#RequestPakagesTempAddForm")[0].reset();
//Unterminated String constant fixed
alert("hola");
}
});
event.preventDefault();
return false; //stop the actual form post !important!
});
productArray 是我创建的要在表单数据中发送的数组。 Controller 上的数组格式是正确的,但序列化的表单数据返回一些奇怪的东西。这是 $this->request->data
返回的内容:
Array
(
[formData] => _method=POST&data%5BRequestPakagesTemp%5D%5Bidentity_id%5D=10&data%5BAddress%5D%5Bexterior_number%5D=22&data%5BAddress%5D%5Binternal_number%5D=0&data%5BAddress%5D%5Bstreet%5D=a&data%5BAddress%5D%5Bsuburby%5D=a&data%5BRequestPakagesTemp%5D%5Btogether%5D=0&data%5BAddress%5D%5Bcountry_id%5D=1&data%5BAddress%5D%5Bstate_id%5D=19&data%5BAddress%5D%5Bcity_id%5D=993&data%5BRequestPakagesTemp%5D%5Bproducts_array%5D=
[productArray] => Array
(
[0] => Array
(
[product_name] => a
[product_number] => a
[category_name] => a
[brand_name] => a
[quantity] => a
[description] => a
)
)
)
我希望表单数据作为我发送的数组发送。我的猜测是我在 ajax 中序列化数据的某个地方搞砸了。感谢您提前提供的帮助:D
我提交的表单就是这个
<?php
echo "<div class='row'>";
echo "<div class='col-lg-4'>";
echo '<div class="styled-select">';
echo $this->Form->input('identity_id', array('empty' => 'Elige la Identidad', 'label' => false, 'placeholder' => 'Identidad', 'class' => 'txtBoxRegister'));
echo '</div>';
echo "</div>";
echo "<div class='col-lg-4'>";
echo $this->Form->input('Address.exterior_number', array( 'label' => false, 'placeholder' => 'Numero Exterior', 'class' => 'txtBoxRegister'));
echo "</div>";
echo "<div class='col-lg-4'>";
echo $this->Form->input('Address.internal_number', array( 'label' => false, 'required' => false, 'placeholder' => 'Número Interior', 'class' => 'txtBoxRegister'));
echo "</div>";
echo "</div>";
echo "<div class='row'>";
echo "<div class='col-lg-4'>";
echo $this->Form->input('Address.street', array( 'label' => false, 'placeholder' => 'Calle', 'class' => 'txtBoxRegister'));
echo "</div>";
echo "<div class='col-lg-4'>";
echo $this->Form->input('Address.suburby', array( 'label' => false, 'placeholder' => 'Colonia', 'class' => 'txtBoxRegister'));
echo "</div>";
echo "<div class='col-lg-4'>";
echo "<div data-toggle='tooltip' data-placement='right' title='Tooltip on right'>";
echo $this->Form->input('together', array('label' => 'Todo Junto', 'class' => 'squaredTwo'));
echo "</div>";
echo "</div>";
echo "</div>";
echo "<div class='row'>";
echo "<div class='col-lg-4'>";
echo '<div class="styled-select">';
echo $this->Form->input('Address.country_id', array('required' => true, 'empty' => '', 'label' => false, 'class' => 'txtBoxRegister'));
echo '</div>';
echo "</div>";
echo "<div class='col-lg-4'>";
echo '<div class="styled-select">';
echo $this->Form->input('Address.state_id', array('required' => true, 'empty' => '', 'label' => false, 'class' => 'txtBoxRegister'));
echo '</div>';
echo "</div>";
echo "<div class='col-lg-4'>";
echo '<div class="styled-select">';
echo $this->Form->input('Address.city_id', array('required' => true, 'empty' => '', 'label' => false, 'class' => 'txtBoxRegister'));
echo '</div>';
echo "</div>";
echo "</div>";
echo $this->Form->input('products_array', array('type' => 'hidden', 'id' => 'product_array'));
?>
productArray 是一种表单,每次提交时我都会向 ProductArray 变量添加一个元素(对象)。这是表格:
<?php
echo '<div class="row">';
echo '<div class="col-lg-12" style = "text-align:center;">';
echo $this->Form->input('product_name', array( 'label' => false,'required' => true, 'placeholder' => 'Nombre del Producto', 'class' => 'txtBoxRegister'));
echo $this->Form->input('product_number', array( 'label' => false, 'required' => false, 'placeholder' => 'Numero del Producto', 'class' => 'txtBoxRegister'));
echo $this->Form->input('brand_name', array( 'label' => false, 'required' => true, 'placeholder' => 'Nombre de la Marca', 'class' => 'txtBoxRegister'));
echo $this->Form->input('category_name', array( 'label' => false, 'required' => true, 'placeholder' => 'Nombre de la Cateogria', 'class' => 'txtBoxRegister'));
echo $this->Form->input('quantity', array( 'label' => false, 'required' => true, 'placeholder' => 'Cantidad del Producto (ejemp. 17 gramos)', 'class' => 'txtBoxRegister', 'id' => 'product_quantity'));
echo $this->Form->input('description', array( 'label' => false, 'required' => true, 'placeholder' => 'Descripción', 'class' => 'txtBoxRegister', 'type' => 'textarea', 'style' => 'height: 150px;', 'id' => 'product_description'));
echo '</div>';
echo '</div>';
?>
这是我将元素添加到数组的 js。
$("#productForm").submit(function( event ) {
//console.log(productArray);
$('#productBodyTable').append('<tr class="productRow" id="' + $("#product_number").val() +'"> <td class="countId">' + count + '</td> <td>' + $("#product_name").val() + '/' + $("#product_number").val() +'</td> <td>' + $("#brand_name").val() + '</td> <td>' + $("#product_description").val() + '</td> <td>' + $("#product_quantity").val() + '</td> <td> <button type="button" class="btn btn-danger delProduct" id="' + $("#product_number").val() + '" value = "' + countP + '"> <b>-</b> </button> </td> </tr>');
event.preventDefault();
var product = { 'product_name': $("#product_name").val(), 'product_number': $("#product_number").val(), 'category_name': $("#category_name").val(), brand_name: $("#brand_name").val(), 'quantity': $("#product_quantity").val(), description: $("#product_description").val()};
//console.log(product);
productArray[countP] = product;
//console.log(productArray);
count = count + 1;
countP = countP + 1;
$('#createIdentityModal').modal('hide');
$('#createIdentityModal').find('form')[0].reset();
$(".delProduct").click(function() {
delete productArray[$(this).val()];
$(this).parent().parent().remove();
//console.log(productArray);
restartCounter();
});
});
顺便说一句,productArray 是一个全局值。
最佳答案
好的,我发现了序列化表单的问题。该方法正在做它应该做的事情。我只是没有在 Controller 端给出它的格式。所以我发现在 Controller 中使用它:
$FormOne = $this->request->data['formData'];
$FormOneValues = array();
parse_str($FormOne, $FormOneValues);
$this->request->data['formData'] = $FormOneValues['data'];
我可以为我获得的表单数据提供我想要的格式。我不明白序列化方法的作用。通过使用 parse_str()
我可以添加具有我需要的格式的表单数据。如果有一种更简单的方法可以从 View 方面做到这一点,我仍然想听听。我仍在学习使用 CakePhp。希望这对将来的人有帮助。
关于javascript - CakePhp 使用 Ajax 提交 - 表单序列化不起作用,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/28748018/
今天有小伙伴给我留言问到,try{...}catch(){...}是什么意思?它用来干什么? 简单的说 他们是用来捕获异常的 下面我们通过一个例子来详细讲解下
我正在努力提高网站的可访问性,但我不知道如何在页脚中标记社交媒体链接列表。这些链接指向我在 facecook、twitter 等上的帐户。我不想用 role="navigation" 标记这些链接,因
说现在是 6 点,我有一个 Timer 并在 10 点安排了一个 TimerTask。之后,System DateTime 被其他服务(例如 ntp)调整为 9 点钟。我仍然希望我的 TimerTas
就目前而言,这个问题不适合我们的问答形式。我们希望答案得到事实、引用资料或专业知识的支持,但这个问题可能会引发辩论、争论、投票或扩展讨论。如果您觉得这个问题可以改进并可能重新打开,visit the
我就废话不多说了,大家还是直接看代码吧~ ? 1
Maven系列1 1.什么是Maven? Maven是一个项目管理工具,它包含了一个对象模型。一组标准集合,一个依赖管理系统。和用来运行定义在生命周期阶段中插件目标和逻辑。 核心功能 Mav
我是一名优秀的程序员,十分优秀!