首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >如何访问Movilizer应答中所选应答项的标签

如何访问Movilizer应答中所选应答项的标签
EN

Stack Overflow用户
提问于 2015-04-28 15:20:29
回答 1查看 68关注 0票数 0

在文本输入屏幕(类型5)中,我有一个下拉输入元素(答案类型6),其中包含几个应答项。在离开OK时,我希望将所选答案项的标签存储在局部变量中。调用getAnswerData会给我应答项的客户端密钥。如何才能访问标签呢?

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2015-04-29 07:09:45

您可以做的是在getAnswerValue中使用onLeaveOkPersistAssignment,并在一个新的本地变量(例如$local:selectedItem )中分配这个值。通过这样做,clientKey将存储在这个var中。在下一个屏幕或后续屏幕上,您可以使用这个clientKey来访问正确的数组pos值。

示例:最初您的问题可能如下所示:

代码语言:javascript
运行
复制
question key="q0" type="5" title="">
            <answer key="q0a0" nextQuestionKey="q1" dummyAnswer="true" attributeType="6">
                <item clientKey="0" dummyAnswerItem="true" />
                <text/>
            </answer>
            <onEnterAssignment>
$local:myArray = 
{
   0:'Product 1';
   1:'Product 2';
   2:'Product 3';
};

addAnswer($answer:'q0a0', null, 'Dropdown List');
for(items:$local:myArray)
{
   addAnswerItem($answer:'q0a0', null, '0', items, $local:myArray[items]);
}
            </onEnterAssignment> 

这个示例包含一个dummyAnswer(key=q0a0)和一个dummyAnswerItem,在onEnterAssignment中使用addAnswer()调用应答,并使用addAnswerItem分配应答项。现在,在这个答案的onLeaveOkPersistAssignment中,您使用的是getAnswerValue(),在使用getAnswerValue时,您要将clientKey分配给本地变量。

代码语言:javascript
运行
复制
<onLeaveOkPersistAssignment>
   $local:selectedItem = getAnswerValue($answer:'q0a0');
</onLeaveOkPersistAssignment>

现在您可以在使用changeEvents的同一屏幕上或在后续屏幕上这样做:

代码语言:javascript
运行
复制
<question key="q1" type="0" title="">
        <answer key="q1a0" nextQuestionKey="END" dummyAnswer="true"/>
            <onEnterAssignment>
               addAnswer($answer:'q1a0', null, $local:myArray[$local:selectedItem]);
           </onEnterAssignment> 
</question>

这允许您在下一个屏幕上打印选定项的标签。

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/29923404

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档