Unterschiede

Hier werden die Unterschiede zwischen zwei Versionen angezeigt.

Link zu dieser Vergleichsansicht

Nächste Überarbeitung
Vorhergehende Überarbeitung
de:create:functions:registervariable [21.12.2014 21:58] – ausgelagert aus functions-proc adminde:create:functions:registervariable [03.10.2023 08:38] (aktuell) – [registerVariable()] admin
Zeile 7: Zeile 7:
   * //VariablenName//\\ Ein String (in Anführungszeichen) mit dem Namen der Variable. Es darf nicht die Variable selbst sein (z.B. ''$item''), ein String mit dem Namen der Variable (z.B. 'item').   * //VariablenName//\\ Ein String (in Anführungszeichen) mit dem Namen der Variable. Es darf nicht die Variable selbst sein (z.B. ''$item''), ein String mit dem Namen der Variable (z.B. 'item').
  
 +**Wichtig:** Änderungen an Variablen werden nur dann in spätere PHP-Codes übernommen, wenn der entsprechende PHP-Code bis zum Ende läuft. Befehle wie ''repeatPage()'', ''goToPage()'' oder ''pageStop()'' unterbrechen die Ausführung, sodass die Änderungen nicht übernommen werden. Bitte beachten Sie, dass dieses Verhalten nach Funktion und Programmversion variiert. Die Verwendung [[:de:create:questions:internal|interner Variablen]] ist hier eine robuste Alternative.
  
-===== Beispiel =====+===== Verwendung mit isset() ===== 
 + 
 +Viele Beispiele in der Anleitung verwenden ''registerVariable()'' zusammen mit der PHP-Funktion ''[[http://php.net/manual/de/function.isset.php|isset()]]'', um eine mehrfache [[de:create:randomization|Randomisierung]] bzw. [[:de:create:rotation|Rotation]] zu vermeiden -- zum Beispiel wenn die Fragebogen-Seite nach dem "Weiter" erneut angezeigt wird, weil noch Antworten fehlen. 
 + 
 +Die Funktion ''isset()'' ermittelt, ob eine PHP-Variable bereits vorher definiert wurde. Damit kann man vermeiden, dass z.B. eine Liste neu erstellt und gemischt wird, wenn sie schon vorher definiert wurde. 
 + 
 +**Wichtig:** Der Inhalt der Variable wird __nicht__ im Datensatz gespeichert und die PHP-Variable wird beim Erreichen der "letzten Seite" (Abschluss des Fragebogens) gelöscht. Falls der Inhalt der Variable (z.B. die Reihenfolge einer Rotation) für die Auswertung relevant ist, muss man sie mittels ''[[:de:create:functions:put]]'' explizit im Datensatz speichern. 
 + 
 +**Wichtig:** Bei der Verwendung von ''registerVariable()'' muss man sich bewusst sein, dass die registrierte Variable für das komplette restliche Interview definiert ist. Wenn man also die Kombination ''registerVariable()'' und ''isset()'' nochmal an anderer Stelle verwenden möchte, sollte man dafür tunlicht eine __andere Bezeichnung für die Variable__ wählen. Zum Beispiel ''$itemsAB'' im ersten PHP-Code und ''$itemsBC'' im zweiten. 
 + 
 + 
 +Hier ein Beispiel, bei welchem die Items einer Frage gezielt gemischt werden: 
 + 
 +<code php> 
 +// Die Klammer wird nur ausgeführt, 
 +// wenn die Variable $items noch nicht definiert wurde, 
 +// also beim ersten Aufuruf dieser Seite - und auch nur dann, 
 +// wenn früher im Fragebogen kein registerVariable($items) steht. 
 +if (!isset($items)) { 
 +  // Hier werden nun die Items der Frage AB01 abgerufen und gemischt 
 +  $items = getItems('AB01'); 
 +  shuffle($items); 
 +  // Und hier wird dafür gesorgt, dass SoSci Survey die Variable $items 
 +  // nicht sofort wieder vergisst, sondern sie für das komplette 
 +  // restliche Interview (inkl. eines eventuellen 
 +  // erneuten Aufrufs der aktuellen Seite) merkt. 
 +  registerVariable($items); 
 +
 +// Hier wird der Inhalt der Variable nun verwendet 
 +question('AB01', $items); 
 +</code> 
 + 
 +Die Variable ''$items'' ist fortan auf jeder weiteren Seite im Fragebogen in jedem PHP-Code definiert. Würde man denselben PHP-Code auf einer weiteren Seite platzieren, dann würde ''isset($items)'' das Ergebnis ''true'' (trifft zu) liefern, die Verneinung mit dem Ausrufezeichen ''!isset($items)'' entsprechend ''false'' (trifft nicht zu). Und damit würde die Klammer nicht mehr ausgeführt, selbst wenn die Variable ''$items'' beim zweiten Mal ganz anders verwendet werden sollte. 
 + 
 +Dieses Beispiel ist dem Kapitel [[:de:create:rotation]] entnommen. Dort finden Sie auch Beispiele zu weiteren Einsatzmöglichkeiten. 
 + 
 + 
 +===== Items einer Frage ziehen =====
  
 Im folgenden Beispiel werden auf Seite 1 zufällig drei Items aus den Items der Frage "AB01" gezogen. Anschließend soll die Frage mit diesen drei Items gestellt werden -- und auf einer späteren Seite soll Frage "AB02" mit eben denselben drei Items abgefragt werden. Im folgenden Beispiel werden auf Seite 1 zufällig drei Items aus den Items der Frage "AB01" gezogen. Anschließend soll die Frage mit diesen drei Items gestellt werden -- und auf einer späteren Seite soll Frage "AB02" mit eben denselben drei Items abgefragt werden.
Zeile 18: Zeile 56:
 question('AB01', $itemliste); question('AB01', $itemliste);
 // Die Variable $itemliste registrieren // Die Variable $itemliste registrieren
-registerVariable('itemliste');+registerVariable($itemliste);
 </code> </code>
  
Zeile 28: Zeile 66:
  
  
-===== Beispiel 2 =====+===== Teilergebnisse/Filter merken =====
  
 Auf Seite 4 im Fragebogen soll anhand eines recht komplexen Filters ermittelt werden, ob der Teilnehmer in Gruppe 1 (Neukunden oder Kunden in Anbahnung eines Geschäfts) oder Gruppe 2 (Altkunden) der Untersuchung fällt. Aufgrund dieser Einordnung sollen später im Interview unterschiedliche Fragen angezeigt werden. Auf Seite 4 im Fragebogen soll anhand eines recht komplexen Filters ermittelt werden, ob der Teilnehmer in Gruppe 1 (Neukunden oder Kunden in Anbahnung eines Geschäfts) oder Gruppe 2 (Altkunden) der Untersuchung fällt. Aufgrund dieser Einordnung sollen später im Interview unterschiedliche Fragen angezeigt werden.
Zeile 41: Zeile 79:
   $gruppe = 2;   $gruppe = 2;
 } }
-registerVariable('gruppe');+registerVariable($gruppe);
 </code> </code>
  
Zeile 65: Zeile 103:
  
  
-===== Beispiel 3 =====+===== Rotation von Inhalten =====
  
-4 Fragen ("AB01" bis "AB04") sollen zusammen mit 4 zugehörigen Textbausteinen ("text1" bis "text4") angezeigt werden -- aber in zufälliger Reihenfolge. Dafür wird auf Seite 1 des Fragebogens ein Array gemischt und via ''registerVariable()'' für die folgenden Seiten verfügbar gemacht. Details s. Kapitel [[:de:create:rotation|Rotation]].+4 Fragen ("AB01" bis "AB04") sollen zusammen mit 4 zugehörigen Textbausteinen ("text1" bis "text4") angezeigt werden -- aber in zufälliger Reihenfolge. Dafür wird auf Seite 1 des Fragebogens ein Array gemischt und via ''registerVariable()'' für die folgenden Seiten verfügbar gemacht. Details s. Kapitel [[:de:create:rotation]].
  
 <code php> <code php>
Zeile 77: Zeile 115:
 ); );
 shuffle($fragen); shuffle($fragen);
-variableRegister('fragen');+registerVariable($fragen);
 </code> </code>
  
Zeile 101: Zeile 139:
 question($fragen[3][0]); question($fragen[3][0]);
 </code> </code>
 +
 +Mehr dazu s. [[:de:create:rotation]].
de/create/functions/registervariable.1419195533.txt.gz · Zuletzt geändert: 21.12.2014 21:58 von admin
 
Falls nicht anders bezeichnet, ist der Inhalt dieses Wikis unter der folgenden Lizenz veröffentlicht: CC Attribution-Share Alike 4.0 International
Driven by DokuWiki