Yii2动态表单,记录数基于变量值

Yii2动态表单,记录数基于变量值,yii2,dynamicform,Yii2,Dynamicform,我不能保存所有记录,只能保存最后一条 在表单中,用户插入年开始和年结束 变量$years(其中$years=Year\u end-Year\u begin)被传递给动态表单 示例: 在2010年和2011年工作,我需要生成两个记录 从2010年工作到2015年,我需要生成六条记录 我不想使用“+”和“-”按钮来生成新记录 每条记录都显示正确的年份值 这是结果: 这是我在while cycle中的表单代码: <?php foreach ($modelsComm as $i =>

我不能保存所有记录,只能保存最后一条

在表单中,用户插入
年开始
年结束

变量
$years
(其中
$years=Year\u end-Year\u begin
)被传递给动态表单

示例:

  • 在2010年和2011年工作,我需要生成两个记录
  • 从2010年工作到2015年,我需要生成六条记录
我不想使用“+”和“-”按钮来生成新记录

每条记录都显示正确的年份

这是结果:

这是我在while cycle中的表单代码:

<?php foreach ($modelsComm as $i => $modelComm): ?>
<div class="item panel panel-default"><!-- widgetBody -->

    <div class="panel-heading">
        <h3 class="panel-title pull-left">id_calcolo</h3>
        <div class="pull-right">
            <button type="button" class="add-item btn btn-success btn-xs"><i class="glyphicon glyphicon-plus"></i></button>
            <button type="button" class="remove-item btn btn-danger btn-xs"><i class="glyphicon glyphicon-minus"></i></button>
        </div>
        <div class="clearfix"></div>
    </div>
    <div class="panel-body">
    <!-- loop begin -->
        <?php
        $n=0;
        while ($n < $years) {
            // necessary for update action.
            if (! $modelComm->isNewRecord) {
                echo Html::activeHiddenInput($modelComm, "[{$i}]id");
            }
        ?>
        <div class="row">
            <div class="col-sm-2">
                <?= $form->field($modelComm, "[{$i}]year")->textInput(['value' => $year_begin+$n]) ?>
            </div>
            <div class="col-sm-4">
                <?= $form->field($modelComm, "[{$i}]worked")->textInput(['maxlength' => true]) ?>
            </div>
        <div class="col-sm-4">
                <?= $form->field($modelComm, "[{$i}]paid")->textInput(['maxlength' => true]) ?>
            </div>
        </div><!-- .row -->
        <?php
        $n++;
        }
        ?>   
        <!-- loop end -->  
    </div>

</div>
<?php endforeach; ?>
我的模型:

public static function tableName()
{
    return 'comm';
}


public function rules()
{
    return [
        [['year', 'worked', ], 'required'],
        [['worked', 'paid'], 'integer'],
    ];
}


public function attributeLabels()
{
    return [
        'id' => 'ID',
        'year' => 'Year',
        'worked' => 'Worked days',
        'paid' => 'Total Paid',
     ];
}
这是model.php:

class Model extends \yii\base\Model
{
/**
 * Creates and populates a set of models.
 *
 * @param string $modelClass
 * @param array $multipleModels
 * @return array
 */
public static function createMultiple($modelClass, $multipleModels = [])
{
    $model    = new $modelClass;
    $formName = $model->formName();
    $post     = Yii::$app->request->post($formName);
    $models   = [];

    if (! empty($multipleModels)) {
        $keys = array_keys(ArrayHelper::map($multipleModels, 'id', 'id'));
        $multipleModels = array_combine($keys, $multipleModels);
    }

    if ($post && is_array($post)) {
        foreach ($post as $i => $item) {
            if (isset($item['id']) && !empty($item['id']) && isset($multipleModels[$item['id']])) {
                $models[] = $multipleModels[$item['id']];
            } else {
                $models[] = new $modelClass;
            }
        }
    }

    unset($model, $formName, $post);

    return $models;

在年份循环中,您使用
$n
,但输入名称中有
$i
。因此,所有输入都使用
[0]
前缀初始化。这就是为什么在服务器端只有最后一条记录


只需将
[{$i}]id
更改为
[{$n}]id
[{$i}]year
更改为
[{$n}]year
等等

您使用的是哪个版本的yii?我在源代码中找不到
Model::createMultiple
。@oakymak我是stackoverflow的新手。我投了赞成票,但我的票还没有出现:)
class Model extends \yii\base\Model
{
/**
 * Creates and populates a set of models.
 *
 * @param string $modelClass
 * @param array $multipleModels
 * @return array
 */
public static function createMultiple($modelClass, $multipleModels = [])
{
    $model    = new $modelClass;
    $formName = $model->formName();
    $post     = Yii::$app->request->post($formName);
    $models   = [];

    if (! empty($multipleModels)) {
        $keys = array_keys(ArrayHelper::map($multipleModels, 'id', 'id'));
        $multipleModels = array_combine($keys, $multipleModels);
    }

    if ($post && is_array($post)) {
        foreach ($post as $i => $item) {
            if (isset($item['id']) && !empty($item['id']) && isset($multipleModels[$item['id']])) {
                $models[] = $multipleModels[$item['id']];
            } else {
                $models[] = new $modelClass;
            }
        }
    }

    unset($model, $formName, $post);

    return $models;