3

我有这个表单,我想修改它以添加一个应该从用户提交的数据生成的 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();
4

1 回答 1

0

您只需要将映射信息添加到 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 Br。张贴

于 2017-11-06T16:07:36.400 回答