如何使用laravel将多个数据从html插入数据库

时间:2014-11-22 16:13:04

标签: php jquery laravel dynamic shopping

我有这个动态表,这是我的问题的预览: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:此视图就像购物车

提前致谢!

1 个答案:

答案 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来处理服务器。但是,使用此解决方案,您不需要更改太多代码即可使其正常工作。