本文介绍了Yii中的单个日期属性如何具有多个字段(D/M/Y)?的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!
问题描述
我想将用户的出生日期带入数据库,并且表中有一个名为 dob 的字段.当我创建模型并添加CRUD时,它会一如既往地为 dob 生成文本字段.但是我想创建三个输入.
I want to take user birth day into my database and there is a field in the table called dob. When I created model and CRUD it generated text field for dob as always. But I want to create three inputs.
- 多年
- 一个月
- 和日期
所以我的问题是如何在模型的表单中添加额外的输入.我当时正在考虑向模型类添加新属性,但是表中没有此类属性.
推荐答案
将字段添加到模型中
public $year;
public $month;
public $date;
将以下方法添加到模型中:
Add these methods to your model:
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表单中使用它们:
You can now use them in your CActiveForm form:
<?php echo $form->textField($model, 'year'); ?>
<?php echo $form->textField($model, 'month'); ?>
<?php echo $form->textField($model, 'date'); ?>
这篇关于Yii中的单个日期属性如何具有多个字段(D/M/Y)?的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持!