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

2 abhängige Selectboxen - An illegal choice has been detected

Eingetragen von axelf (110)
am 18.01.2010 - 14:49 Uhr in
  • Modul-Entwicklung
  • Drupal 6.x

Hi,

ich habe mir ein kleines Modul gebaut, was 2 Selectobxen enthält. Wird in der einen Box was ausgewählt, dann erscheinen die zugehörigen Werte in der 2. Selectbox (mittel Ajax). Nach dem Abschicken sollen unter dem Formular Werte angezeigt werden und oben wiederrum beide Selectboxen. Leider funktioniert das nicht, denn sobald ich das Formular abschicke kommt folgende Fehlermeldung:

An illegal choice has been detected. Please contact the site administrator.

In der 2. Selectbox stehen dann auch gar keine Werte mehr drin, obwohl ich eigentlich eine Datenbankabfrage eingebaut habe (denn nach dem Abschicken wirkt ja Ajax nicht mehr). Ich habe dazu auch im Netz nicht so viel gefunden.

‹ Moduländerung Wie kann ich einem menu item ein Class-Attribut geben? ›
  • Anmelden oder Registrieren um Kommentare zu schreiben

Source?

Eingetragen von Kars-T (1473)
am 18.01.2010 - 17:46 Uhr

Hi,

ich glaube ohne den Source oder wenigstens mehr Informationen wird man dir nicht helfen können.

Du könntest den Source auch hier posten:
http://pastebin.org/

---

Viele Grüße,

Kars-T
XING | comm-press

  • Anmelden oder Registrieren um Kommentare zu schreiben

hier noch der quellcode

Eingetragen von axelf (110)
am 19.01.2010 - 10:07 Uhr

<?php

/**
* Implementation of hook_menu
*/
function vergleich_menu(){

   
$items = array();
   
$items['vergleich'] = array(
       
'title' => 'Test Test Test',
       
'page callback' => 'vergleich_page',
       
'access arguments' => array('access content'),
       
'type' => MENU_SUGGESTED_ITEM,
    );

   
$items['vergleich/fetch/%'] = array(
       
'page callback' => 'vergleich_get_items',
       
'access arguments' => array('access content'),
       
'page arguments' => array(2),
       
'type' => MENU_CALLBACK,
    );
   
    return
$items;
}

function
vergleich_page(){
   
   
$module_path = drupal_get_path('module','vergleich');
   
drupal_add_js($module_path.'/vergleich.js');

   
$db = array('name'=>'Name','vorname'=>'Vorname'); /*nur zum testen*/
   
$selectbox = drupal_get_form('vergleich_form',3);
   
   
$output = theme('vergleich', $db, $selectbox);
    return
$output;
}

/**
* Implementation of hook_theme
*/
function vergleich_theme(){

   return array(
       
'vergleich' => array(
          
'template' => 'vergleich',
           
'arguments' => array('dbData' => NULL, 'selectbox' => NULL),
       ),
       
'vergleich_results' => array(
           
'template' => 'vergleich_results',
           
'arguments' => array('results' => NULL),
       ),
      
'vergleich_form' => array(
          
'arguments' => array('formular' => NULL),
       )
   );

}

/**
* Implementation of preprocess function
*/
function template_preprocess_vergleich($tplVars){

   
// Datenbank
   
$dbData = $tplVars['dbData'];

   
// Selectbox
   
$selectbox = $tplVars['selectbox'];

   
// Variablen im Template
   
$tplVars = $dbData;
   
$tplVars['manufacturer_selectbox'] = $selectbox;

}

function
template_preprocess_vergleich_results($tplVars){

   
$tplVars['result'] = $tplVars['results'];

}

function
vergleich_form($form_state,$maxColumns){
   
   
// Abfrage aller Hersteller
   
....
   
   
$options_manufacturer = array('-- wählen --');
    while(
$row = db_fetch_object($res)){

       
$options_manufacturer[$row->hs] = $row->hs;

    }

   
$form['#redirect'] = false;
   
    for(
$i=1;$i<=$maxColumns;$i++){
       
$options[$i] = array();
       
$form['vergleich']['hs'.$i] = array(
           
'#type' => 'select',
           
'#options' => $options_manufacturer,
           
'#default_value' => $form_state['values']['hs'.$i],
        );
       
       
// hier sollten alle Geräte nach dem abschicken in der 2. Selectbox angezeigt werden
       
if (!empty($form_state['values']) && !empty($form_state['values']['hs'.$i])){
           
$options[$i] = vergleich_get_items($form_state['values']['hs'.$i],1);
        }else{
           
$options[$i] = array('-- wählen --');

        }

      
       
$form['vergleich']['h'.$i] = array(
           
'#type' => 'select',
           
'#options' => $options[$i],
        );
    }
   
   
$form['vergleich']['compare'] = array(
       
'#type' => 'submit',
       
'#value' => 'vergleichen',
       
'#submit' => array('vergleich_form_submit'),
    );
   
    if (!empty(
$form_state['values'])){
          
       
$results = 'Formular abgeschickt';

    }else{

       
$results = 'Formular noch nicht abgeschickt';

    }

   
$form['results'] = array(
       
'#type' => 'item',
       
'#value' => theme('vergleich_results', $results),
    );

    return
$form;
}

function
vergleich_get_items($manufacturer,$type=NULL){

   
// DB-Abfrage - alle Geräte zu einem Hersteller
   
   
$res = db_query($query);
   
$data = array();
    while(
$row = db_fetch_object($res)){
       
$data[] = $row;
    }
   
    return empty(
$type) ? drupal_json($data) : $data;

}

function
vergleich_form_submit($form, &$form_state){
   
$form_state['storage'] = array(
       
$form_state['values']['h1'],
    );

   
$form_state['rebuild'] = TRUE;
}

function
theme_vergleich_form($form){
  
   
$output = '';
   
$output .= '<div class="selectbox-block">';
   
$output .= drupal_render($form['vergleich']['hs1']);
   
$output .= drupal_render($form['vergleich']['h1']);
   
$output .= '</div>';
   
$output .= '<div class="selectbox-block">';
   
$output .= drupal_render($form['vergleich']['hs2']);
   
$output .= drupal_render($form['vergleich']['h2']);
   
$output .= '</div>';
   
$output .= '<div class="selectbox-block">';
   
$output .= drupal_render($form['vergleich']['hs3']);
   
$output .= drupal_render($form['vergleich']['h3']);
   
$output .= '</div>';
   
$output .= '<br style="clear: both;">';
   
$output .= drupal_render($form);
    return
$output;

}
?>

  • Anmelden oder Registrieren um Kommentare zu schreiben

Das Problem ist relativ

Eingetragen von Sense (1559)
am 19.01.2010 - 16:20 Uhr

Das Problem ist relativ einfach erklärt, habe ich bei einem derzeitigen Projekt.
Werte, die in der Select Box nicht enthalten sind, dürfen auch nicht übertragen werden.
Wenn Du also per AJAX Select Boxen veränderst müssen diese Werte in den "#options" der Select Box stehen.

Der einfachste Weg dieses abzufangen:
Alle Werte, die möglich sind in "#options" des selects einzutragen und dann bei Aufruf des Fomulars mit AJAX / Javascript zu ersetzen / entfernen.

  • Anmelden oder Registrieren um Kommentare zu schreiben

So was in der richtung

Eingetragen von axelf (110)
am 19.01.2010 - 20:22 Uhr

So was in der richtung dachte ich mir schon, aber dann müsste ich ja alle möglichen Werte schon vorher in die options eintragen, das wären bestimmt über 500 Einträge. (die ja auch alle im Quelltext stehen)
Also alle 500 Einträge in die options schreiben und dann beim Aufruf der Seite die 2. Selektbox per Javascript erstmal leeren?

  • Anmelden oder Registrieren um Kommentare zu schreiben

genau, anders wirst du keine

Eingetragen von Sense (1559)
am 19.01.2010 - 20:34 Uhr

genau, anders wirst du keine möglichkeit haben dieses zu ermöglichen.
ansonsten löst nur noch ein core hack in der form.inc das problem, in dem das entsprechende "form_set_error" auskommentiert, wovon ich aber abrate.

  • Anmelden oder Registrieren um Kommentare zu schreiben

ok, ich dachte es geht doch

Eingetragen von axelf (110)
am 19.01.2010 - 21:06 Uhr

ok, ich dachte es geht doch irgendwie besser :-) aber danke für deine hilfe.

  • Anmelden oder Registrieren um Kommentare zu schreiben

Options per JS dynamisch zur Validierung nachtragen

Eingetragen von ABaier (1)
am 21.03.2013 - 11:37 Uhr

Hallo zusammen,

ich habe momentan genau das gleiche Anliegen dieses Threads und Probleme mit der Validierung.

Ich lade über eine View und Views Data Source neue Options in ein Select-Feld und benötige nun wohl
auch eine JavaScript-Funktion, um die Optionen für die Validierung der Webform nachzutragen.

Es handelt sich um Termine, die als Multi-Date-Field in einem Veranstaltungs-Content-Type eingetragen
werden. Das erste Select-Feld listet die Namen der Veranstaltungen, das zweite die zugehörigen Termine.
In meinem Fall gibt es pro Termin nur um die zehn Termine, weshalb das Nachtragen funktionieren sollte.
Übertrgen werden die Daten bisher problemlos nur kann ich eben leider das Formular nicht abschicken.

Könntet ihr mir hier evtl. eure Lösung des Problems beschreiben bzw. eine Beispiels-Funktion
schreiben mit der ich die Optionen fix hinterlegen kann?

Über eure Hilfe wäre ich wirklich sehr dankbar!

Mein Code:

$(function() {
  select = $("select#edit-submitted-stuck");
  select.change(function(){
    $.getJSON("/vorstellungen_arg/"+$(this).attr('value'), populateTermine);
  });
});

function populateTermine(data, textStatus) {
  select = $("select#edit-submitted-vorstellung");
  select.removeOption(/./);
  for(i in data.nodes){
    value = data.nodes[i].node.nodeid;
    label = data.nodes[i].node.termin;
    select.addOption(value, label);
  }
  select.val("");
}

Die JSON-Ausgabe hat folgendes Muster:

{"nodes":[{"node":{"nodeid":"vorstellung-72","termin":"03.05.2013 | 10:30"}},{"node":{"nodeid":"vorstellung-73","termin":"20.06.2013 | 10:30"}}]}

  • Anmelden oder Registrieren um Kommentare zu schreiben

Benutzeranmeldung

  • Registrieren
  • Neues Passwort anfordern

Aktive Forenthemen

  • Medien und andere Daten mit Feeds von Drupal 7 auf Drupal 10 migrieren
  • 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
  • Composer nach Umzug
  • [gelöst] Taxonomie Begriffe zeigt nicht alle Nodes an
  • Drupal 11 + Experience Builder (Canvas) + Layout Builder
  • Welche KI verwendet ihr?
Weiter

Neue Kommentare

  • Inzwischen sind wir bei
    vor 1 Tag 5 Stunden
  • Migrieren von D7 auf D8/ D10/ D11
    vor 1 Tag 21 Stunden
  • melde mich mal wieder, da ich
    vor 7 Wochen 6 Tagen
  • Hey danke
    vor 7 Wochen 6 Tagen
  • Update: jetzt gibt's ein
    vor 8 Wochen 14 Stunden
  • Hallo, im Prinzip habe ich
    vor 8 Wochen 5 Tagen
  • Da scheint die Terminologie
    vor 8 Wochen 5 Tagen
  • Kannst doch auch alles direkt
    vor 9 Wochen 2 Tagen
  • In der entsprechenden View
    vor 9 Wochen 2 Tagen
  • Dazu müsstest Du vermutlich
    vor 9 Wochen 2 Tagen

Statistik

Beiträge im Forum: 250235
Registrierte User: 20462

Neue User:

  • marouane.blel
  • capilclinic
  • Quabzibboter

» Alle User anzeigen

User nach Punkten sortiert:
wla9461
stBorchert6003
quiptime4972
Tobias Bähr4019
bv3924
ronald3857
md3717
Thoor3678
Alexander Langer3416
Exterior2903
» User nach Punkten
Zur Zeit sind 0 User und 24 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