Startseite
  • » Home
  • » Handbuch & FAQ
  • » Forum
  • » Übersetzungsserver
  • » Suche
Startseite › Forum › Drupalcenter.de › Module › Modul-Entwicklung ›

Anordnung der Formularfelder

Eingetragen von escobar (10)
am 18.02.2011 - 15:51 Uhr in
  • Modul-Entwicklung
  • Drupal 6.x

Hallo Leute,

ich möchte bei einem Formular die Felder Postleitzahl und Ort nebeneinander setzen.
So soll das dann aussehen: Plz, Ort [EINGABEFELD] [EINGABEFELD]
Im Forum habe ich auch schon einen Beitrag dazu gefunden http://www.drupalcenter.de/node/24998
und wie beschrieben die Felder im Template von Hand erstellt.
Allerdings weiß ich nicht wie ich die Fehlermeldung dort mit einbringen kann wenn das Formular nicht richtig ausgefüllt wurde (class="form-text error").

Bin für jede Hilfe dankbar.

‹ PHP Snippets? Deutsche Sprache durch Installationsprofil einzig im Installationsvorgang ›
  • Anmelden oder Registrieren um Kommentare zu schreiben

Hat denn keiner eine Idee?

Eingetragen von escobar (10)
am 19.02.2011 - 18:12 Uhr

Hat denn keiner eine Idee?

  • Anmelden oder Registrieren um Kommentare zu schreiben

Wie hast du dein bisheriges

Eingetragen von SteffenR@drupal.org (2262)
am 20.02.2011 - 16:54 Uhr

Wie hast du dein bisheriges Template aufgebaut - poste doch den Quellcode mal bitte hier im Thread.
Im Normalfall werden die Fehler mit in die $messages Variable von Drupal geschrieben und entsprechend ausgegeben.

Natürlich kannst du auch über form_set_error eigene Fehlermeldungen für die entsprechenden Formularfelder "setzen".

SteffenR

  • Anmelden oder Registrieren um Kommentare zu schreiben

Hallo, je nach Theme werden

Eingetragen von escobar (10)
am 21.02.2011 - 17:52 Uhr

Hallo,

je nach Theme werden ja die input felder auch rot dargestellt wenn das Formular nicht richtig ausgefüllt wurde. Dabei wird bei class="form-text", error hinzugefügt.
Das sieht dann so aus: class="form-text error"
Dies möchte ich jetzt bei den labels anwenden. Zuerst hatte ich die Function theme_form_element aus includes/form.inc überschrieben. Dort habe ich
drupal_attributes($element['#attributes']) hinzugefügt.
Aber das geht ja so jetzt nicht mehr wenn ich das Formular von Hand anlegen muß um zwei label und zwei Felder nebeneinander zu bekommen.

function formexample_menu() {
  $items['formexample'] = array(
    'title' => 'Viev the form',
    'page callback' => 'formexample_page',
    'access arguments' => array('access content'),
  );

  return $items;
}

/***/
function formexample_page() {
  
    $output = t('example form');
    $output .= drupal_get_form('formexample_form');
  
  return $output;
}

/***/
function formexample_form() {
  
    $form['plz'] = array(
      '#title' => t('Plz'),
      '#type'  => 'textfield',
    );
    $form['ort'] = array(
      '#title' => t('Ort'),
      '#type'  => 'textfield',
    );

    $form['submit'] = array(
      '#type'  => 'submit',
      '#value' => t('submit')
    );
    return $form;
}

/***/
function formexample_form_validate($form, &$form_state) {
  if (!$form_state['values']['plz']) {
    form_set_error('plz', t('Bitte Postleitzahl eintragen'));
  }
  if (!$form_state['values']['ort']) {
    form_set_error('ort', t('Bitte den Ort eintragen'));
  }
}

/***/
function formexample_theme() {
  return array(
    'formexample_form' => array(
     'arguments' => array(),
    )
  );
}

/***/
function theme_formexample_form($form) {

$output .= '

<div class="form-item">
<label for="edit-plz" class="form-text">Plz/</label>
<label for="edit-ort" class="form-text">Ort: </label>

<input type="text" maxlength="128" name="plz" id="edit-plz" size="5" value="" />
<input type="text" maxlength="128" name="ort" id="edit-ort" size="40" value="" />
</div>

<input id="'.$form['#build_id'].'" type="hidden" value="'.$form['#build_id'].'" name="form_build_id" />
<input id="'.$form['form_token']['#id'].'" type="hidden" value="'.$form['form_token']['#default_value'].'" name="form_token" />
<input id="'.$form['form_id']['#id'].'" type="hidden" value="'.$form['form_id']['#value'].'" name="form_id" />

<input type="submit" name="op" id="edit-submit" value="submit"  class="form-submit" />';


  return $output;
}

  • Anmelden oder Registrieren um Kommentare zu schreiben

Du könntest auch beim

Eingetragen von SteffenR@drupal.org (2262)
am 21.02.2011 - 22:05 Uhr

Du könntest auch beim Standardformular bleiben und dir das Ganze mithilfe von CSS zurechtrücken / gestalten. Hast du an diese Möglichkeit schon gedacht ?
Beispielhaft hatte ich dies hier http://www.wigue-malerei.de/kontakt gemacht..

SteffenR

  • Anmelden oder Registrieren um Kommentare zu schreiben

Hallo Steffen, ich kann doch

Eingetragen von escobar (10)
am 22.02.2011 - 14:49 Uhr

Hallo Steffen,

ich kann doch nicht die Reihenfolge der HTML Elemente im Quellcode mit CSS beeinflussen. In deinem Beispiel stehen auch nicht zwei Label nebeneinander gefolgt von zwei Eingabefeldern, sondern: Label – Eingabefeld – Label – Eingabefeld.
So soll das aussehen: Plz/Ort: [EINGABEFELD] [EINGABEFELD].
Plz/Ort sollen direkt nebeneinander stehen. Nicht einzeln über- unter oder neben dem Eingabefeld.

  • Anmelden oder Registrieren um Kommentare zu schreiben

Benutzeranmeldung

  • Registrieren
  • Neues Passwort anfordern

Aktive Forenthemen

  • Dynamische Ansicht von Seiteninhalt (als Tabelle?)
  • Vergabe von Berechtigungen für bestimmte Rollen; mir fehlt der Haken bzw. das „Veröffentlicht“
  • Ich brauche dringen Hilfe zu Updates oder ggf. wwie geht Composer?
  • Medien und andere Daten mit Feeds von Drupal 7 auf Drupal 10 migrieren
  • Rolle erstellen nicht zu finden
  • für drupal11 ein Slider Modul
  • [gelöst] W3CSS Paragraphs Views
  • Drupal 11 neu aufsetzen und Bereiche aus 10 importieren
  • Wie erlaubt man neuen Benutzern auf die Resetseite zugreifen zu dürfen.
  • [gelöst] Anzeigeformat Text mit Bild in einem Artikel, Drupal 11
  • Social Media Buttons um Insteragram erweitern
  • Nach Installation der neuesten D10-Version kein Zugriff auf Website
Weiter

Neue Kommentare

  • Arrrrg. Nix Tabelle :-D /*
    vor 2 Tagen 21 Stunden
  • Textboxen mit Tabelle
    vor 3 Tagen 4 Stunden
  • Du sollst ja auch keine
    vor 3 Tagen 4 Stunden
  • Theme
    vor 3 Tagen 5 Stunden
  • Welches Theme benutzt du
    vor 3 Tagen 10 Stunden
  • Mit Responsive Raster hatte
    vor 4 Tagen 38 Minuten
  • Hallo Alex,um das Häkchen
    vor 4 Tagen 9 Stunden
  • Modul view_unpublished
    vor 5 Tagen 12 Stunden
  • Modul "override node options"
    vor 6 Tagen 7 Stunden
  • Im Grunde ist dass ein
    vor 1 Woche 1 Tag

Statistik

Beiträge im Forum: 250270
Registrierte User: 20477

Neue User:

  • Robertnobia
  • AltonRaf
  • JeffreyPaf

» Alle User anzeigen

User nach Punkten sortiert:
wla9463
stBorchert6003
quiptime4972
Tobias Bähr4019
bv3924
ronald3857
md3717
Thoor3678
Alexander Langer3416
Exterior2903
» User nach Punkten
Zur Zeit sind 0 User und 13 Gäste online.

Hauptmenü

  • » Home
  • » Handbuch & FAQ
  • » Forum
  • » Übersetzungsserver
  • » Suche

Quicklinks I

  • Infos
  • Drupal Showcase
  • Installation
  • Update
  • Forum
  • Team
  • Verhaltensregeln

Quicklinks II

  • Drupal Jobs
  • FAQ
  • Drupal-Kochbuch
  • Best Practice - Drupal Sites - Guidelines
  • Drupal How To's

Quicklinks III

  • Tipps & Tricks
  • Drupal Theme System
  • Theme Handbuch
  • Leitfaden zur Entwicklung von Modulen

RSS & Twitter

  • Drupal Planet deutsch
  • RSS Feed News
  • RSS Feed Planet
  • Twitter Drupalcenter
Drupalcenter Team | Impressum & Datenschutz | Kontakt
Angetrieben von Drupal | Drupal is a registered trademark of Dries Buytaert.
Drupal Initiative - Drupal Association