我有这个表单,我想修改它以添加一个应该从用户提交的数据生成的 slug 字段。
就像用户选择的类别(名称)和内容中的随机单词一样,我还使用 Slugify 来清理 URL:
知道吗?
$u = $this->getUser();
$sl = new Slugify();
$task = new AdsList();
$task->setPostXpr(new DateTime('+1 month'));
$task->setSlug($ans);
$task->setPostedBy($u);
$form = $this->createFormBuilder($task)
->add('title', TextType::class)
->add('content', TextareaType::class)
->add('category', EntityType::class, array(
// query choices from CategoryAd.Name
'class' => 'AppBundle:CategoryAd',
'choice_label' => 'name',
))
->add('postXpr', DateType::class, array(
'widget' => 'single_text',
// this is actually the default format for single_text
'format' => 'yyyy-MM-dd',
'label' => 'Post Expire',
))
->add('save', SubmitType::class, array('label' => 'Create Post'))
->getForm();
您只需要将映射信息添加到 slug 字段的实体中,而不是添加到表单中,然后使用 cocur/slugify
使用 cocur
if ($form->isSubmitted() && $form->isValid()) {
$em = $this->getDoctrine()->getManager();
$entity->setSlug($this->get('cocur_slugify')->slugify($entity->getName()));
$em->persist($entity);
$em->flush();
return $this->redirectToRoute('my_route_to_redirect', array('slug' => $entity->getSlug()));
}
或者你可以使用@Alexander发布的教义扩展