Unterschiede

Hier werden die Unterschiede zwischen zwei Versionen angezeigt.

Link zu dieser Vergleichsansicht

Beide Seiten der vorigen RevisionVorhergehende Überarbeitung
Nächste Überarbeitung
Vorhergehende Überarbeitung
Letzte ÜberarbeitungBeide Seiten der Revision
de:create:questions:text [09.04.2016 14:03] – JavaScript ergänzt adminde:create:questions:text [13.05.2022 16:37] saskia.mueller.577
Zeile 15: Zeile 15:
   * Die [[::de:create:questions:suggest]] zeigt ein Textfeld (bzw. mehrere Kopien davon), für welches eine Reihe von möglichen Antworten hinterlegt sind. Sobald der Teilnehmer einige Buchstaben in das Eingabefeld eingibt, erscheinen passende Antwortoptionen zur Auswahl. Wird eine der vorgegeben Optionen ausgewählt, so wird die Antwort gleich kodiert -- optional kann man dem Teilnehmer gestatten, auch andere Texte einzugeben, die dann als Text im Datensatz abgelegt werden.   * Die [[::de:create:questions:suggest]] zeigt ein Textfeld (bzw. mehrere Kopien davon), für welches eine Reihe von möglichen Antworten hinterlegt sind. Sobald der Teilnehmer einige Buchstaben in das Eingabefeld eingibt, erscheinen passende Antwortoptionen zur Auswahl. Wird eine der vorgegeben Optionen ausgewählt, so wird die Antwort gleich kodiert -- optional kann man dem Teilnehmer gestatten, auch andere Texte einzugeben, die dann als Text im Datensatz abgelegt werden.
   * Beim "Ballontest" wird unter **Bilder und Mediendateien** zunächst ein Bild ins Projektverzeichnis hochgeladen. Die Frage zeigt dann ein ausgewähltes Bild, in welchem Sie ein oder mehrere Texteingabefelder platzieren können.   * Beim "Ballontest" wird unter **Bilder und Mediendateien** zunächst ein Bild ins Projektverzeichnis hochgeladen. Die Frage zeigt dann ein ausgewähltes Bild, in welchem Sie ein oder mehrere Texteingabefelder platzieren können.
 +
 +
 +===== Einschränkungen für den eingegeben Text =====
 +
 +Die offene Texteingabe (wie übrigens auch offene Eingabefelder in anderen Fragetypen) erlaubt eine automatische Überprüfung des Eingabeformats. Dies ist insbesondere dann empfehlenswert, wenn die Befragten Zahlen (z.B. Alter) oder ein Datum eingeben sollen. Aber es sind auch weitere Anwendungen möglich, wenn die Befragten z.B. einen Geldbetrag mit Nachkommastellen oder genau 2 Buchstaben eintragen sollen.
 +
 +Wählen Sie links im **Fragenkatalog** zunächst die Frage und anschließend das Eingabefeld innerhalb der Frage aus. Bei Auswahlfragen wählen Sie die [[:de:create:selection-textinput|Auswahloption mit dem offenen Eingabefeld]].
 +
 +{{:de:create:questions:scr.text.charset1.png?nolink|Auswahl des Eingabefelds in der Navigation}}
 +
 +Alternativ können Sie in der Item-Eingabe innerhalb der Frage auf den Knopf zum Bearbeiten ({{::button.edit3.png?nolink|Knopf: Bearbeiten}}) der Item- bzw. Eingabefeld-Einstellungen klicken.
 +
 +{{:de:create:questions:scr.text.charset3.png?nolink|Detaileinstellungen für ein Eingabefeld aufrufen}}
 +
 +In den Detaileinstellungen für das Eingabefeld finden Sie die //Einschränkungen für die Texteingabe//. Wählen Sie hier bei //Definierte Zeichen// aus, welches Eingabeformat für das Auswahlfeld gelten soll.
 +
 +**Hinweis:** Wenn Sie als //definierte Zeichen// eine "Zahl" oder "Dezimalzahl" festlegen, wird die Eingabe im Eingabefeld standardmäßig rechtsbündig ausgerichtet und die Angabe wird beim Download der Daten als Zahl behandelt. Die "Ziffern" hingegen werden als Text bestehend aus Ziffern behandelt.
 +
 +{{:de:create:questions:scr.text.charset2.png?nolink|Einstellungen für das Format einer offenen Texteingabe}}
 +
 +Je nach gewähltem Format können weitere Einschränkungen festgelegt werden. Bei Zahlen etwas ein Wertebereich oder bei Buchstaben die Anzahl der Zeichen.
 +
 +Für komplexere Formate steht die Einstellung //Regulärer Ausdruck// zur Verfügung. Falls hier etwas eingetragen wird, deaktiviert dies ein eventuell bei //Definierte Zeichen// festgelegtes Format. Ein regulärer Ausdruck, der z.B. zwei Großbuchstaben (ohne Umlaute) und zwei Ziffern erfordert, würde wie folgt aussehen:
 +
 +<code regex>
 +/[A-Z]{2}[0-9]{2}/
 +</code>
 +
 +Für eine ausführliche Dokumentation regulärer Ausdrücke sei auf [[https://www.regular-expressions.info/|regular-expressions.info]] verwiesen.
  
  
Zeile 20: Zeile 49:
  
 Unter anderem verwendet SoSci Survey JavaScript, um etwa die erlaubten Zeichen (Ziffern, Buchstaben, etc.) zu begrenzten. Mittels [[:de:create:javascript|JavaScript]] kann das Verhalten einzelner Eingabelfelder weiter angepasst werden. Unter anderem verwendet SoSci Survey JavaScript, um etwa die erlaubten Zeichen (Ziffern, Buchstaben, etc.) zu begrenzten. Mittels [[:de:create:javascript|JavaScript]] kann das Verhalten einzelner Eingabelfelder weiter angepasst werden.
 +
  
 ==== Formatierungen erlauben ==== ==== Formatierungen erlauben ====
  
-Mithilfe der JavaScript-Bibliothek [[http://www.sceditor.com/|SCEditor]] (in SoSci Survey automatisch verfügbar) können Sie Textfelder so einstellen, dass der Teilnehmer -- ähnlich wie in einer Textverarbeitung -- den Text formatieren kann. Etwa Wörter unterstreichen, Emoticons einfügen, etc.+Mithilfe der JavaScript-Bibliothek [[http://www.sceditor.com/|SCEditor]] (in SoSci Survey automatisch verfügbar) können Sie Textfelder so verändern, dass der Teilnehmer -- ähnlich wie in einer Textverarbeitung -- den Text formatieren kann. Etwa Wörter unterstreichen, Emoticons einfügen, etc.
  
 Erstellen Sie zunächst eine Frage vom Typ "Offene Texteingabe" mit mehrzeiligem (!) Texteingabefeld. Um ein mehrzeiliges Eingabefeld zu erhalten, tragen Sie eine Höhe (z.B. 120 Pixel) für das Eingabefeld ein. Erstellen Sie zunächst eine Frage vom Typ "Offene Texteingabe" mit mehrzeiligem (!) Texteingabefeld. Um ein mehrzeiliges Eingabefeld zu erhalten, tragen Sie eine Höhe (z.B. 120 Pixel) für das Eingabefeld ein.
Zeile 32: Zeile 62:
  
 <code php> <code php>
-option('script', 'jQuery1.x'); +library('SCEditor'); 
-option('script', 'SCEditor'); +
 </code> </code>
  
-Legen Sie unter **Textbausteine und Beschriftungen** einen neuen Textbaustein (z.B. mit der Kennung "jsSCEditor") mit folgendem Inhalt an:+Legen Sie unter **Textbausteine und Beschriftungen** einen neuen Textbaustein (z.B. mit der Kennung "jsSCEditor" und Typ "HTML-Code") mit folgendem Inhalt an:
  
 <code javascript> <code javascript>
Zeile 62: Zeile 91:
  
  
-==== Zeichen zählen ====+==== Zeichen zählen/begrenzen ====
  
-Die möchten für ein Texteingabefeld anzeigen, wie viele Zeichen der Teilnehmer hineingeschrieben hat -- oder wie viele noch geschrieben werden dürfen? Erstellen Sie unter **Textbausteine und Beschriftung** einen Textbaustein (z.B. mit der Kennung "jsCountChars") mit folgendem Inhalt:+Sie können die Anzahl der Zeichen pro Texteingabefeld begrenzen, wenn Sie das Eingabefeld im **Fragenkatalog** auswählen. 
 + 
 +Mit ein wenig JavaScript können Sie für ein Texteingabefeld auch anzeigen, wie viele Zeichen der Teilnehmer bereits geschrieben hat -- oder wie viele noch geschrieben werden dürfen? Erstellen Sie unter **Textbausteine und Beschriftung** einen Textbaustein (z.B. mit der Kennung "jsCountChars", Typ "HTML-Code") mit folgendem Inhalt:
  
 <code javascript> <code javascript>
Zeile 76: Zeile 107:
   var input = document.getElementById(textID);   var input = document.getElementById(textID);
   if (!input) {   if (!input) {
-    alert("Kein Textbaustein mit der Kennung " + textID + " gefunden");+    alert("Kein Texteingabefeld mit der Kennung " + textID + " gefunden");
     return;     return;
   }   }
Zeile 118: Zeile 149:
 Platzieren Sie die Texteingabefrage unter **Fragebogen zusammenstellen** auf einer Seite des Fragebogens. Platzieren Sie die Texteingabefrage unter **Fragebogen zusammenstellen** auf einer Seite des Fragebogens.
  
-Weiterhin müssen Sie ein HTML-Element auf der Seite platzieren, an dessen Stelle die Anzahl der Zeichen angezeigt werden soll. Dies kann etwa direkt im Fragetext sein, in der Beschriftung des Eingabefeldes oder als Textbaustein unter dem Eingabefeld. Das HTML-Element kann etwa wie folgt aussehen:+Weiterhin müssen Sie ein HTML-Tag auf der Seite platzieren, an dessen Stelle die Anzahl der Zeichen angezeigt werden soll. Dies kann etwa direkt im Fragetext sein, in der Beschriftung des Eingabefeldes oder als Textbaustein unter dem Eingabefeld. Das HTML-Element kann etwa wie folgt aussehen:
  
 <code html> <code html>
Zeile 124: Zeile 155:
 </code> </code>
  
-Die Kennung bei ''id'' können Sie frei wählen. Sie muss aber eindeutig sein und darf nicht mit der Kennung eines Items oder einer Frage übereinstimmen (also z.B. nicht nur ''AB01_01'').+Die Kennung bei ''id'' können Sie frei wählen. Sie muss innerhalb der Seite aber eindeutig sein und darf nicht mit der Kennung eines Items oder einer Frage übereinstimmen (also z.B. nicht nur ''AB01_01'').
  
-Anschließend binden Sie den Textbaustein mittels folgendem PHP-Code in den Fragebogen ein -- und zwar unterhalb der Texteingabe-Frage.+Anschließend binden Sie den Textbaustein mittels folgendem PHP-Code in den Fragebogen ein -- und zwar unterhalb der Texteingabe-Frage und ggf. unterhalb des Elements, welches das HTML-Tag enthält.
  
 <code php> <code php>
Zeile 136: Zeile 167:
 </code> </code>
  
-Falls Sie für den Textbaustein eine andere Kennung als "jsCountChars" verwendet haben, müssen Sie die erste Zeile entsprechend anpassen. In den folgenden Zeilen tragen Sie die Kennung der Frage und ggf. die Anzahl der zulässigen Zeichen ein.+Falls Sie für den Textbaustein eine andere Kennung als "jsCountChars" verwendet haben, müssen Sie die erste Zeile entsprechend anpassen. In den folgenden Zeilen tragen Sie die Kennung des Eingabefelds, des HTML-Tags und ggf. die Anzahl der zulässigen Zeichen ein. 
 + 
 + 
 +==== Wörter zählen ==== 
 + 
 +Die Zählung von Wörtern ist ein wenig anspruchsvoller: Wörter können unterschiedlich lang sein und Umlaute enthalten. Deshalb werden zur Zählung reguläre Ausdrücke herangezogen -- im Speziellen die JavaScript-Klasse [[http://xregexp.com/|XRegExp]], welche standardmäßig als PlugIn in SoSci Survey zur Verfügung steht. 
 + 
 +Der folgende HTML-/JavaScript-Code wird unter einem Texteingabefeld "TX01_01" platziert und zeigt dort die Anzahl der Wörter im Textfeld an, wobei ein Wort hier als mindenstens 2 aufeinanderfolgende Buchstaben definiert ist. Diese Definition erfolgt im regulären Ausdruck ''\\p{L}{2,}''. Das ''\\p{L}'' steht für einen Buchstaben oder Umlaut und ''{2,}'' bedeutet, dass 2 oder mehr davon vorhanden sein müssen. 
 + 
 +Am Ende des Codes muss die Kennung des Texteingabefelds eingetragen werden. 
 + 
 +<code javascript> 
 +<!-- Anzeige der Wortanzahl --> 
 +<div style="margin: 2em 0; text-align: right;"> 
 +  <span id="wordcount">--</span> Wörter 
 +</div> 
 + 
 +<script type="text/javascript" src="../plugins/XRegExp/xregexp-all.min.js"></script> 
 +<script type="text/javascript"> 
 +<!-- 
 + 
 +function WordCounter(inputID, outputID) { 
 +  var textinput = document.getElementById(inputID); 
 +  var textout = document.getElementById(outputID); 
 + 
 +  // Wörter sind hier definiert als 2+ Buchstaben 
 +  var tester = new XRegExp("\\p{L}{2,}", "Ag"); 
 + 
 +  function refresh() { 
 +    var text = textinput.value; 
 +    var words = XRegExp.match(text, tester); 
 +    textout.innerHTML = words.length; 
 +  } 
 + 
 +  textinput.addEventListener("keyup", refresh); 
 +  refresh(); 
 +
 + 
 +// Hier die Kennung des Texteingabefelds eintragen 
 +new WordCounter("TX01_01", "wordcount"); 
 + 
 +// --> 
 +</script> 
 +</code> 
 + 
 + 
 +==== Zeilen nacheinander einblenden ==== 
 + 
 +Beim Fragetyp [[:de:create:questions:textmentions|Offene Nennungen]] werden neue Textzeilen angezeigt, wenn die Befragten "oben" etwas eingetragen haben. Dieses Verhalten kann man auch für Fragen des Typs "Texteingabe offen" anwenden. 
 + 
 +Dafür wird die JavaScript-Funktion ''SoSciTools.dynamicRows()'' verwendet. Diese Methode erwartet zwei Parameter, zum einen die Anzahl der leeren Eingabefelder/Zeilen, die "unten" sichtbar sein sollen. Zum anderen eine Liste (Array) der HTML-IDs der Eingabefelder. 
 + 
 +''void **SoSciTools.dynamicRows**(string //Anzahl//, array //Eingabefelder//)'' 
 + 
 +Wenn man etwa die offene Texteingabe "TX03" mit 5 Items hat (Kennungen ''TX03_01'' bis ''TX03_05'') und jeweils 2 leere Eingabefelder anzeigen will, sähe der JavaScript-Code wie folgt aus: 
 + 
 + 
 +<code javascript> 
 +SoSciTools.dynamicRows(2, ["TX03_01", "TX03_02", "TX03_03", "TX03_04", "TX03_05"]); 
 +</code> 
 + 
 +Möchte man dies als HTML-Code in den Fragebogen einbinden, sind natürlich die ''<script>''-Tags zu ergänzen. 
 + 
 +<code html> 
 +<script type="text/javascript"> 
 +<!-- 
 + 
 +SoSciTools.dynamicRows(2, ["TX03_01", "TX03_02", "TX03_03", "TX03_04", "TX03_05"]); 
 + 
 +// --> 
 +</script> 
 +</code> 
 + 
 +Bei mehr Eingabefeldern ist es eleganter, die Liste der HTML-IDs mit einer FOR-Schleife zu erstellen. Für eine offene Texteingabe TX04 mit 40 Items könnte der JavaScript-Code aussehen wie folgt. 
 + 
 +<code javascript> 
 +// Liste der HTML-IDs erstellen 
 +var items = []; 
 +for (var i=1; i<=40; i++) { 
 +    var itemID = new String(i); 
 +    if (i < 10) { 
 +        itemID = "0" + itemID; 
 +    } 
 +    items.push("TX04_" + itemID) 
 +
 + 
 +// Dynamische Anzeige der Items 
 +SoSciTools.dynamicRows(2, items); 
 +</code>
de/create/questions/text.txt · Zuletzt geändert: 10.09.2023 13:31 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