Symfony 的实时模板
实时模板是一些代码片段,用于常用的代码结构,PhpStorm 会在您输入相应模板名称时自动插入这些代码片段。 Symfony 实时模板参考 包含 PhpStorm 中 Symfony 组件的实时模板完整列表。
要让 PhpStorm 为您插入代码片段,请输入实时模板名称(在代码补全建议中,模板标记为 ),然后按 Tab。 要从插入模板中的一个 变量导航到另一个,请按 Tab 和 Shift+Tab。

要编辑 IDE 预配置的 Symfony 实时模板或创建自定义模板,请转到 设置  (Ctrl+Alt+S) | 编辑器 | 实时模板 并展开 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日