PhpStorm 2025.2 Help

Symfony 的实时模板

实时模板是一些代码片段,用于常用的代码结构,PhpStorm 会在您输入相应模板名称时自动插入这些代码片段。 Symfony 实时模板参考 包含 PhpStorm 中 Symfony 组件的实时模板完整列表。

要让 PhpStorm 为您插入代码片段,请输入实时模板名称(在代码补全建议中,模板标记为 ),然后按 Tab。 要从插入模板中的一个 变量导航到另一个,请按 TabShift+Tab

添加 Symfony 实时模板

要编辑 IDE 预配置的 Symfony 实时模板或创建自定义模板,请转到 设置  (Ctrl+Alt+S) | 编辑器 | 实时模板 并展开 Symfony 节点。

Symfony 实时模板设置

Symfony 实时模板参考

模板名称

模板文本

404unless
if ($CONDITION$) { throw $this->createNotFoundException($MESSAGE$); }
action
#[Route(path: '/$PATH$', name: '$ROUTE_NAME$')] public function $NAME$Action() { $END$ }
add
->add('$FIELD$', $CLASSNAME$::class)
addflash
$this->addFlash('$TYPE$','$MESSAGE$');
choice
#[Assert\Choice(choices: ['$CHOICE$'])]
column
#[ORM\Column(name: '$NAME$', type: '$TYPE$', length: $LENGTH$)]
command
namespace $NAMESPACE$; use Symfony\Component\Console\Attribute\AsCommand; use Symfony\Component\Console\Command\Command; use Symfony\Component\Console\Input\InputInterface; use Symfony\Component\Console\Output\OutputInterface; #[AsCommand(name: '$COMMANDNAME$', description: '$DESCRIPTION$')] class $CLASSNAME$ extends Command { protected function configure(): void { $TODO$ } protected function execute(InputInterface $input, OutputInterface $output): int { return Command::SUCCESS; } }
controller
namespace $NAMESPACE$; use Symfony\Bundle\FrameworkBundle\Controller\AbstractController; use Symfony\Component\Routing\Annotation\Route; class $CLASSNAME$ extends AbstractController { #[Route(path: '/$PATH$', name: '$NAME$')] public function someAction($name) { $END$ } }
createquery
$this->getEntityManager() ->createQuery('SELECT $ALIAS$ FROM $ENTITY$ $ALIAS$ WHERE $ALIAS$.$PROPERTY$ = :$PARAMETER$') ->setParameter('$PARAMETER$', $ARGUMENT$) ->execute();
discriminatorcolumn
#[ORM\DiscriminatorColumn(name: '$NAME$', type: '$TYPE$')]
discriminatormap
#[ORM\DiscriminatorMap(['$VALUE$' => $CLASSNAME$::class])]
doctrinecolumn
/** @var $PHPTYPE$ */ #[ORM\Column(name: '$FIELDNAME$', type: '$TYPE$')] private $$$PROPERTYNAME$;
email
#[Assert\Email(message: '$MESSAGE$')]
embeddable
#[ORM\Embeddable]
embedded
#[ORM\Embedded(columnPrefix: '$PREFIX$', class: $ENTITY$::class)]
entity
namespace $NAMESPACE$; use Doctrine\ORM\Mapping as ORM; #[ORM\Entity] #[ORM\Table(name: '$NAME$')] class $CLASSNAME$ { #[ORM\Id] #[ORM\GeneratedValue] #[ORM\Column(type: 'int')] private int $id = 0; public function getId(): int { return $this->id; } }
entityattribute
#[ORM\Entity(repositoryClass: $REPOSITORY$::class)]
formbuilder
$formBuilder = $this->createFormBuilder(); return $formBuilder ->add('$FIELD$', $CLASSNAME$::class)$END$;
formhandle
$form = $this->createForm($CLASSNAME$::class); $form->handleRequest($REQUEST$); if ($form->isSubmitted() && $form->isValid()) { $END$ }
getem
$EM$ = $this->getDoctrine()->getManager();
getrepo
$EM$->getRepository('$ENTITY$');
groups
#[Groups(groups: ['$GROUP$'])]
id
#[ORM\Id]
ignore
#[Ignore]
index
#[ORM\Index(name: '$NAME$', columns: [$COLUMNS$])]
joincolumn
#[ORM\JoinColumn(name: '$NAME$', referencedColumnName: '$REFERENCE$', onDelete: '$DELETE$')]
jointable
#[ORM\JoinTable(name: '$NAME$')]
length
#[Assert\Length(min: $MIN$, max: $MAX$)]
manytomany
#[ORM\ManyToMany(targetEntity: '$TARGET$')]
manytoone
#[ORM\ManyToOne(targetEntity: '$TARGET$')]
notBlank
#[Assert\NotBlank(allowNull: $ALLOWNULL$)]
notNull
#[Assert\NotNull]
onetomany
#[ORM\OneToMany(targetEntity: '$TARGET$')]
onetoone
#[ORM\OneToOne(targetEntity: '$TARGET$')]
persistflush
$EM$->persist($ENTITY$); $EM2$->flush();
querybuilder
$QB$ = $this->createQueryBuilder('p') ->where('p.$PROPERTY$ = :$PARAMETER$') ->setParameter('$PARAM$', $ARGUMENT$) ->getQuery();
redirect
return $this->redirect('$URL$');
removeflush
$EM$->remove($ENTITY$); $EM2$->flush();
rendertwig
return $this->render('$TEMPLATE$.html.twig', [ $VAL$ ]);
repofind
$VAR$ = $this->getDoctrine() ->getRepository('$REPO$') ->$METHOD$($ARG$);
required
#[Required]
route
#[Route(path: '/$PATH$', name: '$NAME$', methods: ['$METHOD$'])]
serializedName
#[SerializedName(serializedName: '$NAME$')]
table
#[ORM\Table(name: '$NAME$')]
type
#[Assert\Type(type: '$TYPE$')]
uniqueEntity
#[UniqueEntity(fields: ['$FIELD$'])]
uniqueconstraint
#[ORM\UniqueConstraint(name: '$NAME$', columns: [$COLUMNS$])]
valid
#[Assert\Valid]
最后修改日期: 2025年 9月 26日