我有4个字段,这些字段将由用户动态创建。

<div class="controls" id="exchange-fields">
           <p>
            <div id='exchange_div'>
            <div class="input-append" id='currency_div1'>
            {{ Form::select('currency_id[]', $currencies, null, array('name'=>'currency_id', 'id'=>'currency_id', 'value'=>'Input::old("currency_id")[0]' )) }}
            </div>

            &nbsp;&nbsp;&nbsp;&nbsp;
            <div class="input-prepend" id='actual_div1'>
            <span class="add-on">Actual</span>
            {{ Form::text('exchange_rate[]', null, array('class'=>'input-medium rate', 'maxlength'=>10, 'id'=>'exchange_rate', 'value'=>'Input::old("exchange_rate")[0]' )) }}
            </div>

            &nbsp;&nbsp;&nbsp;&nbsp;
            <div class="input-append" id='markup_div1'>
            {{ Form::text('exchange_rate_markup[]', null, array('class'=>'input-mini yellow rate', 'maxlength'=>4, 'id'=>'exchange_rate_markup', 'value'=>'Input::old("exchange_rate_markup")[0]' )) }}<span class="add-on">%</span>
            </div>

            &nbsp;&nbsp;&nbsp;&nbsp;
            <div class="input-prepend" id='rate_div1'>
            <span class="add-on">Marked-up</span>
            {{ Form::text('after_markup_rate[]', null, array('class'=>'input-medium yellow', 'maxlength'=>10, 'id'=>'after_markup_rate', 'value'=>'Input::old("after_markup_rate")[0]' )) }}
            </div>


        </div>
        </div>
            &nbsp;&nbsp;&nbsp;&nbsp;
            <div class="controls">
                 <input class="btn btn-primary" type="button" id="addScnt" value="Add">

            </div>


我使用JavaScript来动态填充这些字段。

var scntDiv = $('#exchange-fields');
    var i = $('#exchange-fields p').size() + 1;


    $('#addScnt').click(function() {

     $(scntDiv).append('<p>');
     $("#exchange_div").clone().attr("id",'exchange_div_'+ i).appendTo(scntDiv);

//Append the remove button
    $($('#exchange_div_'+ i)).append('<input class="btn btn-primary" name="remove" type="button" id="remScnt" value="Remove">');
    i++;

    });


在我将这些值发布到我的控制器并且验证失败之前,这是完美的工作方式。
如何使用在视图文件中动态填充的旧输入重新填充这些字段?

我使用return Redirect :: back()-> withInput()-> withErrors($ e-> getErrors());验证失败后无法重新填充这些字段以进行重定向。但是,因为这4个字段仅接受字符串值,并且返回的输入都在数组中,所以验证失败后,我无法重新填充这4个字段。

有什么好的方法可以解决此问题?

提前致谢。

最佳答案

@ a7omiton而不是返回所有输入。我使用Input :: except(array)返回其余不是array的字段。

重定向回时,我使用附加的with()返回字段数组,例如最初加载页面时如何呈现视图。

// If validation fails, ignore those exchange rate fields
//because they are in array not string
$input = Input::except([
    'currency_id',
    'exchange_rate',
    'exchange_rate_markup',
    'after_markup_rate'
]);
// return normally as separate array and it will store in session
return Redirect::back()
    ->withInput($input)
    ->withErrors($e->getErrors())
    ->with('exchange_rate', Input::get('exchange_rate'))
    ->with('currency_id', Input::get('currency_id'))
    ->with('exchange_rate_markup', Input::get('exchange_rate_markup'))
    ->with('after_markup_rate', Input::get('after_markup_rate'));

关于javascript - 验证失败后,Laravel 4将输入重定向回页面,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/21698193/

10-09 16:50