我的任务是向用户显示页面的到期日期。为此,我创建了一个包含两个字段的表单类型,第一个字段允许在 1 周 1 个月和 1 年之间进行选择以及自定义。如果客户选择自定义,则会显示另一个日历字段。在我使用 datatransformer 之后,因为第一个字段返回一个字符串('1week','1year' ...),第二个字段将是 null 或日期问题是反向转换方法工作得很好,但参数transform 方法为空,即当用户想要编辑页面时,他看不到两个字段的最后一个值。
class ExpiryDateType extends AbstractType {
public function buildForm(\Symfony\Component\Form\FormBuilderInterface $builder, array $options) {
$builder ->add("chosen", \Symfony\Component\Form\Extension\Core\Type\ChoiceType::class,array(
'choices' => array(
'1 week' => '7',
'1 month' => '30',
"1 year"=>"365",
"custom"=>"custom"
)))
->add('ExpiryDate', 'sonata_type_date_picker', array('format' => 'yyyy-MM-dd', 'label' => '', 'required' => false))
->addModelTransformer(new \ADS\CoreBundle\Form\DataTransformer\ExpiryDateTransformer());
}
public function configureOptions(\Symfony\Component\OptionsResolver\OptionsResolver $resolver) {}
public function buildView(\Symfony\Component\Form\FormView $view, \Symfony\Component\Form\FormInterface $form, array $options) {
parent::buildView($view, $form, $options);
}
public function getBlockPrefix()
{
return 'expirydate';
}
}
那是变压器
class ExpiryDateTransformer implements DataTransformerInterface {
public function transform($date) {
//date is null !!!!
}
public function reverseTransform($array) {
if ($array["chosen"] == "7") {
$date = new \DateTime("now");
$date->modify("+1 week");
$date->format('Y-m-d H:i:s');
return($date);
} else if ($array["chosen"] == "30") {
$date = new \DateTime("now");
$date->modify("+1 month");
$date->format('Y-m-d H:i:s');
return($date);
} else if ($array["chosen"] == "365") {
$date = new \DateTime("now");
$date->modify("+1 year");
$date->format('Y-m-d H:i:s');
return($date);
} else {
return($array["ExpiryDate"]);
}
}
}