ルートを使用してフォームをロードする方法は2つあります。フォームをロードしてビルド配列の一部として返すコールバックをロードするか、デフォルトで_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) {