我有 AdsList 实体
我想将其添加到 CategoryAd 实体,该实体是 MainCategory 的子类别(我希望这是有意义的)
我希望这基于Dynamic Generation for Submitted Forms 因此,当使用选择其中一个MainCategories时,下一个字段应该填充它的子类别
但我仍然不知道如何根据我的情况调整这个例子
如果这是太多的代码我会做一个要点
AdsList
class AdsList
{
/**
* @ORM\Column(type="integer")
* @ORM\Id
* @ORM\GeneratedValue(strategy="AUTO")
*/
protected $id;
/**
* @ORM\Column(type="string")
*/
protected $title;
/**
* @ORM\Column(type="text")
*/
protected $content;
/**
* @ORM\ManyToOne(targetEntity="CategoryAd", inversedBy="ad")
*/
protected $category;
/**
* @ORM\column(type="date", name="posted_at")
*/
protected $postedAt;
/**
* @ORM\ManyToOne(targetEntity="Agency", inversedBy="ads")
* @ORM\JoinColumn(name="agency_id", referencedColumnName="id")
*/
protected $postedBy;
}
CategoryAd
class CategoryAd
{
/**
* @var int
* @ORM\Column(name="id", type="integer")
* @ORM\Id
* @ORM\GeneratedValue(strategy="AUTO")
*/
private $id;
/**
* @var string
* @Assert\NotBlank()
* @ORM\Column(name="name", type="string", length=255, unique=true)
*/
private $name;
/**
* @ORM\OneToMany(targetEntity="AdsList", mappedBy="category")
*/
private $ad;
/**
* @ORM\ManyToOne(targetEntity="AppBundle\Entity\MainCategory", inversedBy="subCat")
*/
private $parentCat;
/**
* CategoryAd constructor.
*/
public function __construct()
{
$this->ad = new ArrayCollection();
}
MainCategory
class MainCategory
{
/**
* @var int
* @ORM\Column(name="id", type="integer")
* @ORM\Id
* @ORM\GeneratedValue(strategy="AUTO")
*/
protected $id;
/**
* @var string
* @Assert\NotBlank()
* @ORM\Column(name="name", type="string", length=255, unique=true)
*/
protected $name;
/**
* @var
* @ORM\OneToMany(targetEntity="AppBundle\Entity\CategoryAd", mappedBy="parentCat")
* @ORM\JoinColumn(name="cat_id", referencedColumnName="id")
*/
protected $subCat;
/**
* MainCategory constructor.
* @param string $name
*/
public function __construct($name)
{
$this->name = $name;
}
这是表格
目前它的工作原理是,我想做父类别,因为我现在有90个类别,而且它只会得到更多
我不知道ajax,但symfony确实在文档中显示了一个例子
你可以帮忙吗? /**
* @Route("/post", name="post")
*/
public function newAction(Request $request)
{
// create a Post and give it some dummy data for this example
$task = new AdsList();
$task->setpostedAt(new \DateTime('now'));
$form = $this->createFormBuilder($task)
->add('title', TextType::class)
->add('content',TextareaType::class)
->add('category', EntityType::class, array(
// query choices from Category.Name
'class' => 'AppBundle:CategoryAd',
'choice_label' => 'name',
))
->add('postedAt', DateType::class, array(
'widget' => 'single_text',
// this is actually the default format for single_text
'format' => 'yyyy-MM-dd',
))
->add('save', SubmitType::class, array('label' => 'Create Post'))
->getForm();
$form->handleRequest($request);
if ($form->isSubmitted() && $form->isValid()) {
// $form->getData() holds the submitted values iN MeM
$task = $form->getData();
// save the task to the database
$em = $this->getDoctrine()->getManager();
$em->persist($task);
$em->flush();
return $this->redirectToRoute('list');
}
return $this->render('postlist/post.html.twig', array(
'adForm' => $form->createView(),
));
}
答案 0 :(得分:0)
您无法使用链接提交表单的动态生成作为您的用例。 symfony的文档仅涉及动态生成FormType而不是值。
您应该使用javascript来填充数据。我不知道您的FormType和下一个字段是怎样的,但是每次选择主类别并正确填充字段时,您都可以创建一个检索子类别的ajax调用。如果您使用CollectionType,则只需使用原型。