只是想知道使用Yii框架从DOB中计算年龄的最佳方法是什么。
我有一个包含以下字段的模型。
'id' => 'ID',
'firstname' => 'Firstname',
'surname' => 'Surname',
'dob' => 'Dob',
'age' => 'Age',
然后在我的_form.php文件中,我正在尝试编辑它,以便即时计算年龄
<?php $form = ActiveForm::begin(); ?>
<?php
$currentDate=date('Y-m-d');
$dob=$model->dob; //Careful with initialization???
$model->age=$currentDate-$dob;
?>
<?= $form->field($model, 'firstname')->textInput(['maxlength' => 50]) ?>
<?= $form->field($model, 'surname')->textInput(['maxlength' => 50]) ?>
<?= $form->field($model, 'dob')->widget(
DatePicker::className(), [
// inline too, not bad
'inline' => false,
// modify template for custom rendering
'template' => '<div class="well well-sm" style="background-color: #fff; width:250px">{input}</div>',
'clientOptions' => [
'autoclose' => true,
'format' => 'yyyy-mm-dd'
]
]);?>
<?php echo Html::activeHiddenInput($model, 'age') ;
<div class="form-group">
<?= Html::submitButton($model->isNewRecord ? 'Create' : 'Update', ['class' => $model->isNewRecord ? 'btn btn-success' : 'btn btn-primary']) ?>
</div>
<?php ActiveForm::end(); ?>
当然这里有一个问题,因为要获得$ model-&gt; dob,首先必须提交表单,所以当完成年龄计算时,dob是未经启动的。
我想知道的是,我可以先从dob字段读取,以便正确计算年龄?
或者这最好是通过数据库中的触发器来完成的吗?
期待听到回复。
干杯。
答案 0 :(得分:1)
在您的用户模型中,添加:
public $age;
public function getAge()
{
// age in format yyyy-mm-dd
if(isset($this->age)) return $this->age;
else {
$dob = explode("-", $this->dob);
$age = (date("md", date("U", mktime(0, 0, 0, $dob[1], $dob[2], $dob[0]))) > date("md")
? ((date("Y") - $dob[2]) - 1)
: (date("Y") - $dob[2]));
$this->age = $age;
return $age;
}
}
然后您可以在需要的地方拨打$model->getAge()
。 (如果$ model是您的用户模型,那么。)