Anordnung der Formularfelder
Eingetragen von escobar (10)
am 18.02.2011 - 15:51 Uhr in
am 18.02.2011 - 15:51 Uhr in
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.
- Anmelden oder Registrieren um Kommentare zu schreiben
Hat denn keiner eine Idee?
am 19.02.2011 - 18:12 Uhr
Hat denn keiner eine Idee?
Wie hast du dein bisheriges
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
http://www.twitter.com/_steffenr
Drupal-Initiative e.V.
Hallo, je nach Theme werden
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;
}
Du könntest auch beim
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
http://www.twitter.com/_steffenr
Drupal-Initiative e.V.
Hallo Steffen, ich kann doch
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.