Symfony 4表单集合和原型

3

我是一名初学者,正在尝试使用Symfony 4渲染一个包含数值选择的ChoiceType表单字段,以生成用户所选择的确切数量的标签。

这是我的控制器:

class ContactController extends AbstractController
{
    /**
     * @Route("/matrix", name="matrix")
     */
    public function index(Request $request)
    {
        $contact = new Contact();
// i've already added some tags
        $tag3 = new Tag();
        $tag3->setName('tag3');
        $contact->getTags()->add($tag3);

        $tag4=new Tag();
        $tag4->setName('ciao');
        $contact->getTags()->add($tag4);

        $form = $this->createForm(ContactType::class, $contact);
        $form->handleRequest($request);


        if ($form->isSubmitted() && $form->isValid()) {

            $contactFormData = $form->getData();
            dump($contactFormData);
        }

        return $this->render('contact/index.html.twig', array(
            //'our_form' => $form,
        'form' => $form->createView(),
        ));
    }

在我的代码这一点上,表单似乎已经填好了,我用一些转储进行了检查。

这是我的twig:

{% block body %}
    <div>
        {{ form_start(form) }}
        {{ form_widget(form) }}
        <ul class="tags" data-prototype="{{ form_widget(form.tags.vars.prototype)|e('html_attr') }}">
            {% for tag in form.tags %}
                <li> {{ form_row(tag.name) }}
                </li>
            {% endfor %}
        </ul>
    <input type="submit" value="Send" class="btn btn-success" />
    {{ form_end(form) }}
</div>

{% endblock %}

看起来这两个文件之间没有可见性,实际上,他不能进入 for 循环。我已经转储了一些东西,发现标签此时没有子元素,但其实应该有子元素。

class ContactType extends AbstractType
{
    public function buildForm(FormBuilderInterface $builder, array $options)
    {
        $builder
            ->add('motto')
            ->add('expectations', ChoiceType::class, array(
                'choices'  => array(
                    '1' => '1',
                    '2' => '2',
                    '3' => '3',
                    '4' => '4',
                    '5' => '5',


                ),
            ));

$builder->add('tags', CollectionType::class, array(
    'entry_type' => TagType::class,
    'entry_options' => array('label' => false),
    'allow_add' => true,
    'by_reference' => false,
    'mapped' => false,

));

    }

    public function configureOptions(OptionsResolver $resolver)
    {
        $resolver->setDefaults([
            // Configure your form options here
        ]);
    }
}

嘿,为什么不来我们的聊天室(https://chat.stackoverflow.com/rooms/165794/php-mysql-html-css-js-jq-wordpress)? - Mr X
你能展示一下 ContactType::class 的代码吗? - DonCallisto
1个回答

0

我对这段代码感到困惑 => $contact->getTags()->add($tag3);。看起来Tags是一个实体,而Contact是另一个实体,因此您的Contact实体应该具有adders/removers和/或setters/removers(即使累加两者都不是必要的)。

所以你的实体应该像这样:

class Contact
{
    // ...

    /** @var Collection */
    protected $tag;

    // ...

    public function __construct()
    {
        $this->tags = new ArrayCollection();
    }

    // ...

    public function addTag(Tag $tag)
    {
        $this->tags->add($tag);
    }

    public function removeTag(Tag $tag)
    {
        // ...
    }
}

实现你的案例的一个很好的例子:如何嵌入一组表单

然后,我不知道你的TagType表单是什么样子,但即使它开发得很好,你的twig也不对。

首先,form_widget(form)会渲染整个表单

来自Symfony文档

渲染给定字段的HTML小部件。如果将其应用于整个表单或字段集合,则将渲染每个底层表单行。

因此,重新渲染集合将没有效果。即使你的twig代码不是渲染集合的好方法。


网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接