Laravel 4形式模型绑定与动态形式不适当填充

时间:2014-03-21 16:19:45

标签: php mysql forms laravel-4 model-binding

我无法让动态表单正确加载。我有一个表单,用户可以单击一个按钮并将输入字段添加到他们的内容中。我已经能够json_encode并存储信息,但是当我尝试编辑表单时,Laravel只创建并填充默认输入,省去了用户创建的输入字段和数据。如何让Laravel的表单模型绑定显示其他字段和信息?或者我只是错误地形成模型绑定?用户可以按“添加另一个围栏”,并将表单的另一个副本添加到底部。因此,在这种情况下(我没有包括整个表格,因为它很长),他们可以按“添加另一个围栏”按钮和另一个带有“gateNumber”类的输入,并且会出现新创建的“gateNumber_2”ID在底部。如果有人知道如何让动态数据绑定和显示或指出我出错的地方,将不胜感激!非常感谢你!

以下是我编辑的路线:

/*Edit Orders (GET)*/
Route::get('orders/{orders}/edit', array(
    'as'    => 'order-edit',
    'uses'  => 'OrderController@getEdit'
));
/*Edit Order (POST)*/
    Route::post('/orders/{orders}/edit', array(
    'as'    => 'order-edit-post',
        'uses'  => 'OrderController@postEdit',
    ));

查看(或至少是一个片段,表单很长):

@extends('layout.main')
@section('content')
{{ Form::model($order, array('route'=>array('order-edit-post', $order->id), 'name', '=', 'orderForm', 'id', '=', 'orderForm')) }}
 <fieldset id="customerInfo">
     {{ Form::label('order_name', 'Order Name:')}}
     {{ Form::text('order_name') }}
        @if($errors->has('order_name'))
    {{ $errors->first('order_name') }}
    @endif
<legend><strong>Gate Information</strong></legend>
    {{ Form::select('gateNumber_1',
        array(
            'select'    => 'Gates Needed',
            '0'         => '0',
            '1'         => '1',
            '2'         => '2',
            '3'         => '3',
    ), null,
    array('class'       => 'gateNumber')) }}
<div>
    <input type="button" id="btnAddFence" value="Add Another Fence" />
    <input type="button" id="btnDelFence" value="Remove Fence" />
</div>  

和订单控制器:

public function getEdit($id){
        $order = Order::where('id', '=', $id);

        if($order->count()) {
            $order = $order->first();
            $order->order_serialized = json_decode($order->order_serialized);

            foreach($order->order_serialized as $key => $value){
                $order->$key = $value;
            }
            return View::make('orders.edit')
                    ->with('order', $order);
        }   else {
            return App::abort(404);
        }
    }

    public function postEdit($id){
        $validator = Validator::make(Input::all(),
            array(
                'order_name'            =>'required',
                'phone'                 =>'required|min:10|numeric',
                'email'                 =>'required',
                'st_address'            =>'required',
                'post_date'             =>'required',
            )           
        );

        if($validator->fails()){
            return Redirect::route('order-edit', $id)
                    ->withErrors($validator)
                    ->withInput()
                    ->with('global', 'You done messed up.');
        }   else {
            /*Edit Order*/
            $order                      = Order::find($id);

            $order->order_name          = Input::get('order_name');
            $order->phone               = Input::get('phone');
            $order->email               = Input::get('email');
            $order->st_address          = Input::get('st_address');
            $order->post_date           = Input::get('post_date');
            $order->order_serialized    = json_encode(Input::except('_token', 'submit'));

            if($order->save()){
                return Redirect::route('home')
                        ->with('global', 'Your order has been edited.');
            }
        }

        return Redirect::route('home')
                ->with('global', 'Your order could not be edited.');

    }

1 个答案:

答案 0 :(得分:2)

使用时,Laravel会将数据绑定到您的表单:

{{ Form::model($order, ...) }}

{{ Form::text('order_name') }}

但是在你的javascript中,你没有使用后者来创建这些新字段。

无论如何,这是你不能通过Javascript做的事情,你必须在PHP(Laravel)中执行它。但是,您可以通过ajax从数据库中收集此信息。