#yii2
#yii2
Вопрос:
Я пытаюсь сохранить расписание рабочих дней в таблице сразу в нескольких строках… Я делаю это неправильно, все еще выдавая ошибки. Я видел табличные входные данные от других, но не могу понять это правильно. Мне действительно нужны другие взгляды на это.
У меня такая же проблема, как https://phppedia.com/en/knowledge-base/32481399/yii2-insert-multiple-records-of-a-same-table
Модель:
public
function rules()
{
return [
['store_id', 'string'],
['day', 'string'],
['start_hour', 'string'],
['end_hour', 'string'],
['holiday','boolean'],
];
}
контроллер:
public function actionCreate()
{
$count = count(Yii::$app->request->post('Openhour', []));
$model = [new Openhours()];
for ($i = 1; $i < $count; $i ) {
$model[] = new Openhours();
}
if ($model->loadMultiple($model, Yii::$app->request->post())) {
foreach ($model as $model) {
$model->save(false);
}
}
return $this->render('create', ['model' => $model,]);
}
_form
<?php $stores = Stores::getAll() ?>
<?php foreach ($stores as $store): ?>
<?php if ($store->id !== 0): ?>
<?php $listData[$store->id] = [$store->id => $store->title]; ?>
<?php endif; ?>
<?php endforeach; ?>
<?php $form = ActiveForm::begin(['enableAjaxValidation' => true, 'options' => ['class' => 'model-form'],]); ?>
<?php foreach ($model as $index => $model): ?>
<div class="row row-cols-3">
<div class="col">
<h5>
<?php if ($store->title === Yii::$app->user->identity->username) : ?>
<?= $form->field($model, '[$index]store_id')->hiddenInput(['value' => $store->title])->label($store->title) ?>
<?php else: ?>
<?= $form->field($model, '[$index]store_id')->dropDownList($listData, ['prompt' => 'Select...']); ?>
<?php endif; ?>
</h5>
</div>
<div class="col">Opening</div>
<div class="col">Close</div>
</div>
<?php $days = Storedays::getAll() ?>
<?php foreach ($days as $day): ?>
<div class="row row-cols-3">
<div class="col">
<div class="row justify-content-between">
<div class="col">
<h6><?= $day->name ?></h6>
<?= $form->field($model, '[$index]day')->hiddenInput(['value' => $day->name, 'id' => 'day' . $day->id])->label(false) ?>
</div>
<div class="col">
<?= $form->field($model, '[$index]holiday')->checkbox(['selected' => $model->holiday, 'id' => 'holiday' . $day->id])->label(false) ?>
</div>
</div>
</div>
<div class="col">
<?= $form->field($model, '[$index]start_hour')->Input('text')->widget(TimePicker::class, ['options' => ['id' => 'start_hour' . $day->id], 'pluginOptions' => ['maxHours' => '8', 'template' => 'dropdown', 'showSeconds' => false, 'showMeridian' => false, 'minuteStep' => 15,]])->label(false) ?>
</div>
<div class="col">
<?= $form->field($model, '[$index]end_hour')->Input('text')->widget(TimePicker::class, ['options' => ['id' => 'end_hour' . $day->id], 'pluginOptions' => ['maxHours' => '8', 'template' => 'dropdown', 'showSeconds' => false, 'showMeridian' => false, 'minuteStep' => 15,]])->label(false) ?>
</div>
</div>
<?php endforeach; ?>
<?php if (IS_ROOT) : ?><?= $form->field($model, '[$index]slug') ?><?php endif; ?>
<?= Html::submitButton('save', ['class' => 'btn btn-primary']) ?>
<hr class="mb-3">
<?php endforeach; ?>
<?php ActiveForm::end(); ?>
Комментарии:
1. дамп переменной
$model
перед foreach. Давайте проверим, что ваш post загружен в массив с объектами. Также установите другую переменную в foreach. Например:foreach($model as $item){....}
2. @vvpanchev, сбросил $model это объект, изменил $model на $item на контроллере, вызывает функцию-член loadMultiple() для массива: if ($model-> loadMultiple($model, Yii:: $app-> request-> post())). можетвы помогаете?
3. объект или массив объектов?
4. измените его только в foreach, потому что теперь вы foreach model в model … оба с одинаковыми именами..
5. array(1) {[0]=> object(…modulesopenhoursmodelsOpenhours)#126 (10) { [«_attributes»:»yii db BaseActiveRecord»:private]=> array(0) { } [«_oldAttributes»:»yii dbBaseActiveRecord»:private]=> NULL [«_related»:»yii db BaseActiveRecord»:private]=> массив (0) { } … все еще выдает ту же ошибку Слишком долго, потому что здесь мы можем пообщаться где-нибудь еще?
Ответ №1:
Сначала у вас есть массив объектов, и вместо этого вы должны использовать множественное имя.
Итак model
, станьте models
.
Во-вторых, вы должны использовать функции для загрузки нескольких моделей из запроса Model::loadMultiple($models)
и для проверки нескольких моделей Model::validateMultiple($models)
.
Теперь в вашем контроллере:
public function actionCreate()
{
$count = count(Yii::$app->request->post('Openhour', []));
$models = [new Openhours()];
for ($i = 1; $i < $count; $i ) {
$models[] = new Openhours();
}
if (Model::loadMultiple($models, Yii::$app->request->post()) amp;amp; Model::validateMultiple($models)) {
foreach ($models as $model) {
$model->save(false);
}
}
return $this->render('create', ['models' => $models]);
}
Теперь в вашем _form.php
изменении строки:
<?php foreach ($model as $index => $model): ?>
Для:
<?php foreach ($models as $index => $model): ?>