javascript - 使用带有嵌入式 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);
}
});
推荐阅读
- static-analysis - klocwork:kwconan 失败并显示“错误:无法继续:无法验证表”
- php - 如何上传大于 10MB 的文件?
- javascript - 如果一个字符串在 JavaScript 中是不可变的,为什么下面的代码会改变一个字符串?
- python-3.x - 我无法在 python 中安装请求模块
- javascript - UseState,UseEffect 不更新 reactjs 中的状态。我正在尝试向状态添加随机数
- typescript - TypeScript:如何计算从日期到今天的天数
- javascript - Threejs中的可点击按钮效果
- python - 如何使用 Python 读取文本文件并将其存储在二维列表中?
- angular - 未找到模块:错误:无法解析“ace/edit_session”
- c# - 您将如何压缩仅包含“F”和“G”的 256 字节字符串?