一種選擇是導出調查,編輯導出文件並將調查重新導入到Qualtrics中。這種方法在Qualtrics支持中沒有很好的記錄,但它確實有效。 This help file解釋瞭如何將Qualtrics調查導出和導入爲QSF文件(即Qualtrics調查格式文件)。
因此,主要的挑戰是解決如何以添加相關的Java腳本200次編輯QSF。
QSF文件採用JSON格式。在此之前,我曾聽說過,但從未使用過JSON格式。也許這是Qualtrics用戶的典型特徵。
默認情況下,QSF文件是串行形式(即,它是在一行中)。我發現this online editor有助於格式化和解析QSF文件的層次結構。 ![json qsf files qualtrics](https://i.stack.imgur.com/G0f4J.png)
通常,QSF文件的結構以SurveyEntry
開頭,該文件具有一般調查規範。然後它有一堆SurveyElements
。我的例子中的前六個元素與調查的一般特徵有關。特別是,第一個元素代表塊,並列出了塊中問題的順序。在前六個問題之後。每個問題都包含一系列ID類型變量,然後是Payload
。 Payload
包括控制問題特徵的核心屬性 - 值對。
具體地,對於一個問題的JavaScript保持在QuestionJS
變量。我不認爲Payload中屬性的順序很重要,但我不確定。
所以這個任務只是在每個問題的Payload
屬性中添加一些像這樣的代碼。
"QuestionJS":"Qualtrics.SurveyEngine.addOnload(function()\n{\n var that = this;\n this.questionclick = function(event,element){\n if (element.type == 'radio') {\n that.clickNextButton();\n }\n }\n\n\n});",
據推測,有更好的利用數據結構的編輯JSON腳本的更好的方法,但它應該可以做一個簡單的查找和替換。例如,如果你所有的問題的類型都是選擇題,你可以不喜歡
查找:
"QuestionType":"MC",
更換
"QuestionType":"MC","QuestionJS":"Qualtrics.SurveyEngine.addOnload(function()\n{\n var that = this;\n this.questionclick = function(event,element){\n if (element.type == 'radio') {\n that.clickNextButton();\n }\n }\n\n\n});",
這個想法可以擴展到你想要的其他場合將特定屬性添加到一組問題中。
謝謝。你的方法會很好。但是,我嘗試了這種方法,但它不起作用。也就是說,我試着將我的問題(即'var that = this'等)中顯示的代碼粘貼到標題中。你認爲它需要適應頭部的工作嗎?也就是說,作爲跨問題的一般腳本工作? –
使用一些其他腳本我可以得到標題工作,但只爲第一個問題,根據這個問題:https://stackoverflow.com/questions/31754742/why-does-my-qualtrics-js-in-header-only-似乎是工作的首頁 –
你需要調整你的腳本,因爲'這'不再是問題(即this.questionId)。你必須讓腳本找到問題。在您遇到的其他問題上,在外觀和感覺下,將頁面切換設置爲「無」。另外,最佳做法是將JavaScript放在頁腳中。 –