我有一个表单,其中的输入字段是这样的
<div class="row">
<?php echo $form->labelEx($model,'due_date'); ?>
<?php
$this->widget('zii.widgets.jui.CJuiDatePicker',
array(
'attribute'=>'due_date',
'model'=>$model,
'options' => array(
'mode'=>'focus',
'dateFormat'=>'d MM, yy',
'showAnim' => 'slideDown',
),
'htmlOptions'=>array('size'=>30,'class'=>'date'),
)
);
?>
<?php echo $form->error($model,'due_date'); ?>
</div>
我已经将此表单保存在模型文件中。它是这样的
protected function beforeSave()
{
$this->due_date=date('Y-m-d', strtotime(str_replace(",", "", $this->due_date)));
return TRUE;
}
CJuiDatePicker用于保存日期选择器中的数据。在保存时,它以d mm yy格式显示日期,但当我要更新表单时,日期以yy MM d格式显示。如果我要更改beforeSave的日期格式,(),它正在以0000-00-00值存储日期格式。没有存储其他日期值。有人能告诉我哪里做错了吗?任何帮助和建议都将不胜感激。
4条答案
按热度按时间zsohkypk1#
试试看:
把上面的代码添加到你的模型中。它应该可以工作了。
e5njpo682#
我对欧洲日期也有类似的问题,格式如下:'dd/mm/yyyy',这是我使用的:
在模型规则中:
因为'medium'区域设置格式符合我的验证需要。
在我使用的形式中:
以及转换回MySQL格式,以便保存、日期比较......:
希望这对你有帮助。
kninwzqo3#
这对我很有效:
2izufjch4#