Symfony Forms - Добавление входного массива - PullRequest
0 голосов
/ 30 мая 2018

Итак, я пытаюсь создать входной массив для своей формы, но пока не нашел в документации никаких ресурсов для этого (я мог что-то пропустить, поэтому ссылка в этом случае).

ВКороче говоря, я хотел бы сделать что-то вроде этого:

<select name="my-select" id="some-select">
    <option value="a">A</option>
    <option value="b">B</option>
    <option value="c">C</option>
</select>

<button type="button" class="btn btn-primary" id="add-new-option">
    Add Another Option
</button>

, поэтому идея состоит в том, что пользователь может выбрать вариант A, нажать кнопку, чтобы добавить вариант C, а также A к объекту.

Результаты опций сохраняются в следующей таблице:

entity_id  option_value
1          A
1          C
2          B
2          A

Я думал просто сделать это так:

foreach ($arrayInput as $key => $value)
{
    $option = new Option();
    $option->setEntityId($entity->getId());
    $option->setOptionValue($value);
}

в контроллере.

Но у меня ужасное чувство, что уже есть способ сделать это, я просто не смог его найти.В противном случае мне придется использовать HTML в моих шаблонах веток, и я стараюсь уменьшить это ..

Итак, является ли вышеуказанный метод лучшим способом достижения того, чего я хочу?

Моя текущая сущность:

<?php

namespace App\Entity;

use Doctrine\ORM\Mapping as ORM;

/**
 * @ORM\Entity(repositoryClass="App\Repository\PageRepository")
 */
class Page
{
    /**
     * @ORM\Id()
     * @ORM\GeneratedValue()
     * @ORM\Column(type="integer")
     */
    private $id;

    /**
     * @ORM\Column(type="string", length=125)
     */
    private $title;

    /**
     * @ORM\Column(type="text")
     */
    private $content;

    /**
     * @ORM\Column(type="boolean")
     */
    private $approved;

    /**
     * @ORM\Column(type="datetime")
     */
    private $created_ts;

    /**
     * @ORM\Column(type="datetime", nullable=true)
     */
    private $last_edit_ts;

    /**
     * @ORM\Column(type="integer")
     */
    private $author_id;

    /**
     * @ORM\ManyToOne(targetEntity="App\Entity\Tag")
     */
    private $tag;

    public function getTag(): ?Tag
    {
        return $this->tag;
    }

    public function getId()
    {
        return $this->id;
    }

    public function getTitle(): ?string
    {
        return $this->title;
    }

    public function setTitle(string $title): self
    {
        $this->title = $title;

        return $this;
    }

    public function getContent(): ?string
    {
        return $this->content;
    }

    public function setContent(string $content): self
    {
        $this->content = $content;

        return $this;
    }

    public function getApproved(): ?bool
    {
        return $this->approved;
    }

    public function setApproved(bool $approved): self
    {
        $this->approved = $approved;

        return $this;
    }

    public function getCreatedTs(): ?\DateTimeInterface
    {
        return $this->created_ts;
    }

    public function setCreatedTs(\DateTimeInterface $created_ts): self
    {
        $this->created_ts = $created_ts;

        return $this;
    }

    public function getLastEditTs(): ?\DateTimeInterface
    {
        return $this->last_edit_ts;
    }

    public function setLastEditTs(?\DateTimeInterface $last_edit_ts): self
    {
        $this->last_edit_ts = $last_edit_ts;

        return $this;
    }

    public function getAuthorId(): ?int
    {
        return $this->author_id;
    }

    public function setAuthorId(int $author_id): self
    {
        $this->author_id = $author_id;

        return $this;
    }
}

Спасибо

1 Ответ

0 голосов
/ 30 мая 2018

Вы можете использовать ChoiceType (для строк) или EntityType (для сущностей) с 'multiple' => true.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...