こちらのサイトではDRUPAL10に関連する記事を掲載しています。
Drupalでは「モジュール」と呼ばれる、小さなソフトウェアを実装することで機能拡張を行います。本ウェビナーシリーズでは、Drupalのモジュール開発に関する基礎知識を解説します。Drupalのバックエンド周りについて体系的に学びたい方、自分でカスタムモジュールを作れるようになりたい方、アクイア認定デベロッパー試験を目指す方におすすめです。
Drupalを一通り操作したことがある方を対象としています。まだDrupalを触ったことが無い方は、初心者向けDrupalチュートリアル動画(日本語)を先に見ておくとより理解が深まります。
DrupalのForm APIとは
DrupalのFormは以下のようにさまざま
data:image/s3,"s3://crabby-images/8c16e/8c16e133625fd75ecd63a25b7df2de3af143ae64" alt=""
これらはFormAPIで実装されている
FormAPIとは
data:image/s3,"s3://crabby-images/653f5/653f514ddb449963d14456752fe38222648cf986" alt=""
FormAPIのメリット
data:image/s3,"s3://crabby-images/07eba/07eba8f1d3570d9aad0600ecf063d61154ec80f9" alt=""
SQLインジェクション対策など実装者側が特に意識しなくても適切なHTMLコードを作成してくれる
フォーム実装の流れ
data:image/s3,"s3://crabby-images/cb928/cb92848fb48592a00ff5ccf66938d0d8ca0d2708" alt=""
data:image/s3,"s3://crabby-images/9596b/9596b332cc107536dd2410219e6d5ae0febd895d" alt=""
フォームクラスを用意する
モジュールのディレクトリの直下に以下のファイルを作成する
data:image/s3,"s3://crabby-images/acb69/acb693a168d2be6f3f982a12dc91f20f057e6b71" alt=""
メソッドを実装する
<?php
namespace Drupal\test123form_module\Form;
use Drupal\Core\Form\FormBase;
use Drupal\Core\Form\FormStateInterface;
class Test123Form extends FormBase {
public function getFormId() {
return "my_form";
}
public function buildForm(array $form, FormStateInterface $form_state) {
$form['name'] = [
'#type' => 'textfield',
'#title' => '名前',
];
$form['submit'] = [
'#type' => 'submit',
'#value' => '送信',
];
return $form;
}
public function submitForm(array &$form, FormStateInterface $form_state) {
$this->messenger()->addStatus('ご入力ありがとうございました!');
}
}
yamlファイルを設定する
INFOファイルを作成する
name: test123form module
type: module
description: 'FORM機能をテストするモジュール'
package: Custom
core_version_requirement: ^8.7.7 || ^9 || ^10
ルーティングを設定する
test123form_module.form:
path: '/testform'
defaults:
_form: '\Drupal\test123form_module\Form\Test123Form'
_title: 'Test form page'
requirements:
_permission: 'access content'
フォームの種類
種類
data:image/s3,"s3://crabby-images/9cae2/9cae26f504727b6a47d27543eca4e7602bbedca2" alt=""
関係性
data:image/s3,"s3://crabby-images/17379/1737968c2b6b896a6752ca07de3f92562cce44aa" alt=""
FormBaseが一般的に使用されるフォーム用のベースクラス。
ConfigFormBaseは設定画面用に拡張されたもの、ConfirmFormBaseは確認画面用に拡張されたもので、それぞれベースになるものはFormBaseである。
FormBase
data:image/s3,"s3://crabby-images/e63b0/e63b0d0e0d765414e1594697cd423122b40b4465" alt=""
ConfigFormBase
data:image/s3,"s3://crabby-images/936a5/936a57f246caf068b7e9d6e1c6de6571db02b563" alt=""
ConfirmFormBase
data:image/s3,"s3://crabby-images/cbd17/cbd1722c4d4152ae61c16a00c0ba242fe29d7273" alt=""
フォームクラスのメソッド
getFormId()
フォームに一意のIDを付与するために必要
※必ず一意になるように設定すること
buildForm()
HTMLを生成する
data:image/s3,"s3://crabby-images/1a2ab/1a2abb8fb583003c4869c8583fc8e956012a79e1" alt=""
validateForm()
バリデーションチェックが必要な場合に使用する
※FormBaseを拡張するクラスはオプション
data:image/s3,"s3://crabby-images/fa729/fa729414099c75dbe2535c37a4d5d2fc16217a37" alt=""
submitForm()
data:image/s3,"s3://crabby-images/275cc/275cc8705ced0887320352cd2e31700c16aa50de" alt=""
フォームのレンダリング
フォーム配列は、HTMLフォームを構築するための連想配列。
要素と属性を連想配列で指定する
- 属性は#をつける
- 要素は#をつけない
data:image/s3,"s3://crabby-images/5cdbc/5cdbcb5fb63fba8ace0769574d9ba53bb4b173b5" alt=""
指定可能な属性の例
data:image/s3,"s3://crabby-images/ddf65/ddf654827d48dc8c7200609bdce42ff7c2442a06" alt=""
指定可能な属性の詳細についてはこちらを参照
指定可能な属性の例
data:image/s3,"s3://crabby-images/c69d4/c69d43b80a1a392c66e916071ed672be2130127d" alt=""
data:image/s3,"s3://crabby-images/c69d4/c69d43b80a1a392c66e916071ed672be2130127d" alt=""
フォームの取得と表示
フォームの変更
練習問題
data:image/s3,"s3://crabby-images/7d5ed/7d5ed69dd0ff7a2da07206300e646f76ea379ee1" alt=""
この記事またはDrupalに関するご質問がございましたら、お気軽にお問い合わせください。