Scroll
          
        12.15.3. Dependency Injection im BaseForm
In den vorherigen Artikeln haben wir besprochen, was Services und Dependency Injection (DI) sind und wie man sie in seinem Controller und Block verwendet:
12.15. Services und Dependency Injection.
12.15.1. Dependency Injection im Controller
12.15.2. Dependency Injection im Block
In diesem Artikel ein Beispiel, wie man Services ĂĽber DI in eine Formular-Klasse, die von FormBase erbt, hinzufĂĽgt:
<?php
namespace Drupal\drupalbook\Form;
use Symfony\Component\DependencyInjection\ContainerInterface;
use Drupal\Core\Form\FormBase;
use Drupal\Core\Form\FormStateInterface;
use Egulias\EmailValidator\EmailValidator;
/**
 * Klasse ModalForm.
 */
class ModalForm extends FormBase {
  /**
   * E-Mail Validator.
   *
   * @var \Egulias\EmailValidator\EmailValidator
   */
  protected $emailValidator;
  /**
   * Konstruktor eines neuen ModalForm.
   *
   * @param \Egulias\EmailValidator\EmailValidator $email_validator
   *   Der E-Mail Validator.
   */
  public function __construct(EmailValidator $email_validator) {
    $this->emailValidator = $email_validator;
  }
  /**
   * {@inheritdoc}
   */
  public static function create(ContainerInterface $container) {
    return new static(
      $container->get('email.validator')
    );
  }
  /**
   * {@inheritdoc}
   */
  public function getFormId() {
    return 'drupalbook_contact_form';
  }
  /**
   * {@inheritdoc}
   */
  public function buildForm(array $form, FormStateInterface $form_state, $options = NULL) {
    $form['email'] = [
      '#type' => 'email',
      '#title' => $this->t('Email'),
      '#description' => $this->t('Your email address'),
      '#required' => TRUE,
    ];
    $form['actions']['send'] = [
      '#type' => 'submit',
      '#value' => $this->t('Send'),
    ];
    return $form;
  }
  /**
   * E-Mail Validierung.
   */
  protected function validateEmail(array &$form, FormStateInterface $form_state) {
    if (!$this->emailValidator->isValid($form_state->getValue('email'))) {
      return FALSE;
    }
    return TRUE;
  }
  /**
   * {@inheritdoc}
   */
  public function validateForm(array &$form, FormStateInterface $form_state) {
    $email = $form_state->getValue('email');
    if (!empty($email)) {
      if (!$this->validateEmail($form, $form_state)) {
        $form_state->setErrorByName('email', $this->t('%email ist keine gĂĽltige E-Mail-Adresse.', ['%email' => $email]));
      }
    }
    else {
      $form_state->setErrorByName('email', $this->t("Bitte geben Sie eine E-Mail-Adresse ein."));
    }
    $form_state->setValue('email', $email);
  }
  /**
   * {@inheritdoc}
   */
  public function submitForm(array &$form, FormStateInterface $form_state) {
    
  }
  /**
   * Gibt die Konfigurationsnamen zurĂĽck, die bearbeitbar sind.
   *
   * @return array
   *   Ein Array von Konfigurationsobjektnamen, die bearbeitet werden können, wenn die config()-Methode des Traits verwendet wird.
   */
  protected function getEditableConfigNames() {
    return ['config.drupalbook_contact_form'];
  }
}
Um einen Service ĂĽber DI im Formular zu verwenden, nutzen wir die Methoden __construct und create(), genauso wie wir es fĂĽr den Block gemacht haben.