有两种使用路由加载表单的方法。您可以加载用于加载表单并作为构建数组的一部分返回的回调,也可以通过将_form参数设置为默认值来直接加载表单。
您可以搜索代码库以找到可用的示例,将其复制到mymodule.routing.yml中,根据需要进行编辑,然后重新构建缓存。
从回调加载表格:
联系人模块中有一个工作示例:
/core/modules/contact/contact.routing.yml
entity.user.contact_form:
path: '/user/{user}/contact'
defaults:
_title: 'Contact'
_controller: '\Drupal\contact\Controller\ContactController::contactPersonalPage'
requirements:
_access_contact_personal_tab: 'TRUE'
user: \d+
然后在/core/modules/contact/src/Controller/ContactController.php中
您可以看到有关如何在回调中加载表单的示例:
public function contactPersonalPage(UserInterface $user) {
// Do not continue if the user does not have an email address configured.
if (!$user->getEmail()) {
throw new NotFoundHttpException();
}
$message = $this->entityManager()->getStorage('contact_message')->create(array(
'contact_form' => 'personal',
'recipient' => $user->id(),
));
$form = $this->entityFormBuilder()->getForm($message);
$form['#title'] = $this->t('Contact @username', array('@username' => $user->getDisplayName()));
$form['#cache']['contexts'][] = 'user.permissions';
return $form;
}
直接从路线加载表格:
如果您想使用_form默认值直接加载表单,则在/core/modules/shortcut/shortcut.routing.yml的快捷方式模块中有一个示例
shortcut.set_switch:
path: '/user/{user}/shortcuts'
defaults:
_form: 'Drupal\shortcut\Form\SwitchShortcutSet'
_title: 'Shortcuts'
requirements:
_custom_access: 'Drupal\shortcut\Form\SwitchShortcutSet::checkAccess'
options:
_admin_route: TRUE
user: \d+
在这种情况下,会将用户作为参数传递给表单,请参见/core/modules/shortcut/src/Form/SwitchShortcutSet.php
public function buildForm(array $form, FormStateInterface $form_state, UserInterface $user = NULL) {