如何解决使用带有嵌入式 Qualtrics 变量的 Javascript
我正在使用 Qualtrics 收集与行为经济学相关的实验数据。
我需要为受访者提供预算,然后在整个调查过程中随着他们的支出更新预算。
我编写了一个玩具示例来尝试在此处获取 javascript。他们在问题上花费预算后,我无法更新预算。
这里是问题和底层 javascript。 谁能指出我哪里出错了?
第 0 步:我在调查开始时将嵌入的数据字段“预算”设置为 100 美元。
第 1 步:我显示第一页。
*Q1:您的预算为 ${e://Field/Budget} 这显示正确。
*Q2:要花多少钱? (打开文本字段,验证为数字。)
Javascript:
{
});
Qualtrics.SurveyEngine.addOnReady(function()
{
});
Qualtrics.SurveyEngine.addOnPageSubmit(function(type)
{
if(type == "next")
{
var prevbudget = Qualtrics.SurveyEngine.getEmbeddedData("Budget");
var prevbudget = parseInt(prevbudget);
console.log(prevbudget);
//var temp = Qualtrics.SurveyEngine.getTextValue("QID2"); //creates an error
var temp = "${q://QID2/ChoiceTextEntryValue}"
console.log(temp) //null
var temp = parseInt(temp)
var budget = prevbudget-temp;
Qualtrics.SurveyEngine.setEmbeddedData('Budget',budget);
}
});
Qualtrics.SurveyEngine.addOnUnload(function()
{
});
第 2 步:我显示包含更新信息的下一页。
*Q3:您的预算是 ${e://Field/Budget}。 不显示
您之前花费了 ${q://QID2/ChoiceTextEntryValue}。 正确显示
*Q4:要花多少钱? (打开文本字段,验证为数字。)
...理想情况下,这个过程会继续,询问更多的支出和显示预算的问题。
在我看来,我对 Qualtrics API 或 javascript 的理解有问题。有什么想法吗?
解决方法
几点:
- 在页面发送到浏览器之前解析管道。因此,您无法从当前页面通过管道传递值。
- 您的预算必须是一个数字。在前面添加一个 '$' 使它成为一个字符串。
更新代码(假设预算是一个数字,文本输入是一个数字):
Qualtrics.SurveyEngine.addOnPageSubmit(function(type) {
if(type == "next") {
var prevbudget = parseInt("${e://Field/Budget}");
var temp = parseInt(jQuery("#"+this.questionId+" .InputText").val());
var budget = prevbudget-temp;
Qualtrics.SurveyEngine.setEmbeddedData('Budget',budget);
}
});
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。