logo

Extra Block Types (EBT) - Neue Erfahrung im Layout Builder❗

Extra Block Types (EBT) - gestylte, anpassbare Blocktypen: Diashows, Registerkarten, Karten, Akkordeons und viele andere. Eingebaute Einstellungen für Hintergrund, DOM Box, Javascript Plugins. Erleben Sie die Zukunft der Layouterstellung schon heute.

Demo EBT-Module EBT-Module herunterladen

❗Extra Absatztypen (EPT) - Erfahrung mit neuen Absätzen

Extra Paragraph Types (EPT) - analoger, auf Absätzen basierender Satz von Modulen.

Demo EPT-Module EPT-Module herunterladen

Scroll
19/06/2025, by Ivan

Verwendung von $config im Formular-Kontext

Sie können Konfigurationsformulare verwenden, um zu verstehen, wie $config die vom Benutzer eingegebenen Daten abrufen und die Daten in der Datei {module}.settings.yml ändern kann. Hier ist der Code zur Deklaration des $config-Objekts im Formular, den Sie in der PHP-Datei der Formulareinstellungen finden.

Die Klasse Drupal Core ConfigFactory ist der Weg, um Konfigurationsdaten zu lesen und zu schreiben. Sie wird verwendet, um eine Instanz des Config-Objekts basierend auf dem Inhalt der angegebenen Konfigurationsdatei zu erstellen. Das neue Config-Objekt kann dann verwendet werden, um CRUD-Operationen auf diesen Daten durchzuführen.

Config

Beispiel für die Definition eines Formulars (befindet sich in example/src/Form/exampleSettingsForm.php):

namespace Drupal\example\Form;

use Drupal\Core\Form\ConfigFormBase;
use Drupal\Core\Form\FormStateInterface;

/**
 * Konfiguration der example Einstellungen für diese Seite.
 */
class ExampleSettingsForm extends ConfigFormBase {

  /** 
   * Konfigurationseinstellungen.
   *
   * @var string
   */
  const SETTINGS = 'example.settings';

  /** 
   * {@inheritdoc}
   */
  public function getFormId() {
    return 'example_admin_settings';
  }

  /** 
   * {@inheritdoc}
   */
  protected function getEditableConfigNames() {
    return [
      static::SETTINGS,
    ];
  }

  /** 
   * {@inheritdoc}
   */
  public function buildForm(array $form, FormStateInterface $form_state) {
    $config = $this->config(static::SETTINGS);

    $form['example_thing'] = [
      '#type' => 'textfield',
      '#title' => $this->t('Things'),
      '#default_value' => $config->get('example_thing'),
    ];  

    $form['other_things'] = [
      '#type' => 'textfield',
      '#title' => $this->t('Other things'),
      '#default_value' => $config->get('other_things'),
    ];  

    return parent::buildForm($form, $form_state);
  }

  /** 
   * {@inheritdoc}
   */
  public function submitForm(array &$form, FormStateInterface $form_state) {
    // Konfiguration abrufen.
    $this->configFactory->getEditable(static::SETTINGS)
      // Die übermittelten Konfigurationseinstellungen setzen.
      ->set('example_thing', $form_state->getValue('example_thing'))
      // Sie können mehrere Konfigurationen gleichzeitig setzen, indem
      // Sie mehrere set()-Aufrufe machen.
      ->set('other_things', $form_state->getValue('other_things'))
      ->save();

    parent::submitForm($form, $form_state);
  }

}

Routing-Datei (example.routing.yml):

example.settings:
  path: '/admin/config/example/settings'
  defaults:
    _form: '\Drupal\example\Form\ExampleSettingsForm'
    _title: 'example'
  requirements:
    _permission: 'administer site configuration'

Mit dem Config-Objekt können Sie die aus dem Formular gesammelten Daten einfach verarbeiten. Mit dem obigen Code in der Formulareinstellungsdatei können Sie Formulardaten in {module}.settings.yml speichern.

Jede Klasse, die ConfigFormBase erweitert, muss die Methode getEditableConfigNames implementieren und ein Array von Konfigurationsfeldnamen zurückgeben, die sie bearbeitet.

Drupal’s online documentation is © 2000-2020 by the individual contributors and can be used in accordance with the Creative Commons License, Attribution-ShareAlike 2.0. PHP code is distributed under the GNU General Public License.