php – Yii2形式的关系属性

我试图弄清楚在Yii2中处理接收关系数据的表单的正确方法.我没有找到任何好的例子.我有2个模型Set和SetsIntensity,每个Set可能有一个与之关联的SetsIntensity.我正在尝试制作一个可以同时输入的表格.我不知道如何处理在SetsIntensity中获取特定字段“强度”的输入.

哪里

$model = new \app\models\Sets();

如果我把它放在这样的字段中,那么客户端验证将不起作用,并且属性名称不明确并且保存变得困难

<?= $form->field($model, 'lift_id_fk') ?>
<?= $form->field($model, 'reps') ?>
<?= $form->field($model, 'sets') ?>
<?= $form->field($model, 'type') ?>
<?= $form->field($model, 'setsintensity') ?>

我想做这样的事情,但如果我这样做,我会收到错误

<?= $form->field($model, 'setsintensity.intensity') ?>
Exception (Unknown Property) 'yii\base\UnknownPropertyException' with message 'Getting unknown property: app\models\Sets::setsintensity.intensity'

我可以在控制器中创建另一个对象$setsintensity = new Setsintensity();但我觉得这是一个麻烦的解决方案,可能不是很好的做法,尤其是处理多种关系

<?= $form->field($setsintensity, 'intensity') ?>

来自SetsModel的相关代码

class Sets extends \yii\db\ActiveRecord
{

    public function scenarios() {
        $scenarios = parent::scenarios();
        $scenarios['program'] = ['lift_id_fk', 'reps', 'sets', 'type', 'intensity'];
        return $scenarios;
    }

public function rules()
{
    return [
        [['lift_id_fk'], 'required'],
        [['lift_id_fk', 'reps', 'sets','setsintensity'], 'integer'],
        [['type'], 'string', 'max' => 1],
        ['intensity', 'safe', 'on'=>'program']
    ];
}
public function getSetsintensity()
{
    return $this->hasOne(Setsintensity::className(), ['sets_id_fk' => 'sets_id_pk']);
}

SetsIntensity模型

class Setsintensity extends \yii\db\ActiveRecord
{

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

    public function rules()
    {
        return [
            [['sets_id_fk', 'intensity', 'ref_set'], 'required'],
            [['sets_id_fk', 'intensity', 'ref_set'], 'integer']
        ];
    }

    public function getSetsIdFk()
    {
        return $this->hasOne(Sets::className(), ['sets_id_pk' => 'sets_id_fk']);
    }
}

我也想也许我可以为’Sets’中的特定属性’intensity’设置一个hasOne()关系

解决方法:

你应该试试这个:

<?= $form->field($model->setsintensity, 'intensity') ?>

编辑:因为“每个Set可能有一个SetsIntensity”,你应该在显示表单之前检查这个关系,例如:

if ($model->setsintensity===null)
{
    $setsintensity = new SetsIntensity;
    $model->link('setsintensity', setsintensity);
}

PS:link方法要求主键值不为空.

上一篇:mySQL – 插入三个表


下一篇:76.Python中F表达式详解