如何在Yii中为单个日期属性设置多个字段(D / M / Y)?

我想将用户的出生日期带入数据库,并且表中有一个名为dob的字段.当我创建模型和CRUD时,它一如既往地为dob生成了文本字段.但是我想创建三个输入.

>多年
>几个月
>和日期

所以我的问题是如何在模型的表单中添加额外的输入.我当时正在考虑向模型类添加属性,但是表中没有此类属性.

解决方法:

将字段添加到模型中:

public $year;
public $month;
public $date;

将这些方法添加到模型中:

protected function afterFind() {
    parent::afterFind();

    $dob = explode('/', $this->dob);
    $this->year = $dob[0];
    $this->month = $dob[1];
    $this->date = $dob[2];

    return $this;
}

protected function beforeSave() {
    parent::beforeSave();

    $this->dob = $this->year .'/'. $this->month .'/'. $this->date;

    return $this;
}

您现在可以在CActiveForm表单中使用它们:

<?PHP echo $form->textField($model, 'year'); ?>
<?PHP echo $form->textField($model, 'month'); ?>
<?PHP echo $form->textField($model, 'date'); ?>

相关文章

1、将Yii2.0advanced版中应用主体frontend或backend应用复制...
Yii2restfulAPI文档一、配置模块:1.Config/main.php:  2...
Yii在framework/i18n/data/%lang%.php文件中有很多翻译.这...
在Yii2中,官方的页面多语言解决方案有两个:方案1,使用Yii...
Yii2.0对数据库查询的一些简单的操作1234567891011121314151...
数据查询User::find()->all();此方法返回所有数据;User:...