我有这个动态表,这是我的问题的预览:Link to image
<div class="col-sm-7">
<h4>Estado:</h4>
<div class="row">
<div class="col-xs-12">
<div class="table-responsive">
<table class="table preview-table">
<thead>
<tr>
<th>Sexo</th>
<th>Color</th>
<th>Raza</th>
<th>Tipo</th>
<th>Precio x kg</th>
<th>Peso</th>
<th>Monto</th>
</tr>
</thead>
<tbody></tbody> <!-- preview content goes here-->
</table>
</div>
</div>
</div>
我用这个Jquery
添加行$(function(){
var cont = 1;
$('.preview-add-button').click(function(){ //Introduce los nuevos campo
var form_data = {};
form_data["sexo"] = $('.payment-form #sexo option:selected').text();
form_data["color"] = $('.payment-form input[name="color"]').val();
form_data["raza"] = $('.payment-form #raza option:selected').text();
form_data["tipo"] = $('.payment-form #tipo option:selected').text();
form_data["precio"] = $('.payment-form input[name="precio"]').val();
form_data["peso"] = $('.payment-form input[name="peso"]').val();
form_data["monto"] = parseFloat($('.payment-form input[name="precio"]').val()*$('.payment-form input[name="peso"]').val()).toFixed(2);
form_data["remove-row"] = '<span class="glyphicon glyphicon-remove"></span>';
var row = $('<tr></tr>');
$.each(form_data, function( type, value ) {
$('<td class="input-'+type+'"><input type="hidden" class="form-control" name="data-'+type+'" value="'+value+'"></td>').html(value).appendTo(row);
cont++;
});
$('.preview-table > tbody:last').append(row);
calc_total();
$('#sexo').val('');
$('#color').val('');
$('#raza').val('');
$('#tipo').val('');
$('#precio').val('');
$('#peso').val('');
}); });
我的控制器
public function getCreate()
{
$client_options = DB::table('cliente_proveedores')->orderBy('nombre', 'asc')->where('proveedor', '=', 1)->where('activo', '=', 1)->lists('nombre','id');
$tipos_ganados = DB::table('tipos_ganados')->orderBy('tipo', 'asc')->where('activo', '=', 1)->lists('tipo','id');
$razas = DB::table('razas')->orderBy('raza', 'asc')->where('activo', '=', 1)->lists('raza','id');
return View::make('compras.create', array('client_options' => $client_options, 'tipos_ganados' => $tipos_ganados, 'razas' => $razas));
}
/**
* Store a newly created resource in storage.
*
* @return Response
*/
public function store()
{
$compra = new Compra;
$compra->fecha = Input::get('fecha');
$compra->num_factura = Input::get('num_factura');
$compra->id_proveedor = Input::get('proveedor');
$compra->nombre_vendedor = Input::get('nombre_vendedor');
$compra->total = Input::get('total');
$compra->descuento = Input::get('desc');
$compra->itbms = Input::get('itbms');
$compra->total_bruto = Input::get('total_bruto');
if($compra->save()){
$detalle = new DetalleCompra();
$detalle->id_compras = Compra::orderBy('id','DESC')->get();
$detalle->id_ganado = Input::get('num_factura');
$detalle->precio_kilo = Input::get('data-precio');
$detalle->peso = Input::get('data-peso');
$detalle->precio_bruto = Input::get('data-monto');
$detalle->save();
}
if($compra->save()){
Session::flash('message','Guardado Correctamente');
Session::flash('class','success');
}else{
Session::flash('message','Ha ocurrido un error');
Session::flash('class','danger');
}
return Redirect::to('/compras');
}
我如何将它们插入到不同的表中?...我应该使用DB :: table('detalle_compras') - &gt; insert();或者应该用输入替换它们
PD:此视图就像购物车
提前致谢!
答案 0 :(得分:0)
首先要知道,您可以使用array[]
表示法作为名称属性,为同一名称发送多个值。如下所示:
<input type="text" name="test[]" />
<input type="text" name="test[]" />
<input type="text" name="test[]" />
如果您在服务器上收到数据,它可能如下所示:
array('one', 'two', 'three');
(一两三是在三个输入框中输入的值)
我们如何利用这个?
对于每一行,添加名称为[]
的输入字段。例如name="data-peso[]"
。确保这些行在表单中,以便实际上与其他行一起提交。
然后,在你的控制器中。使用普通Input::get()
接收值。您可以使用任何值,因为所有值都应该相同,以获取行数并循环遍历每一行以提取值并保存模型。
for($i = 0; $i < count(Input::get('data-peso')); $i++){
$detalle = new DetalleCompra();
$detalle->peso = Input::get('data-peso')[$i];
$detalle->precio_bruto = Input::get('data-monto')[$i];
// the other values...
$detalle->save();
}
那应该是它。
让我说完成同样的事情还有其他方法。例如,您可以使用javascript来处理客户端的行,并使用json
来处理服务器。但是,使用此解决方案,您不需要更改太多代码即可使其正常工作。