现在的位置: 首页 > 综合 > 正文

在InfoPath Forms Services中实现联动下拉列表框(三)

2014年02月15日 ⁄ 综合 ⁄ 共 769字 ⁄ 字号 评论关闭
在重复表中实现联动下拉列表框

如果用前面两篇文章的方法在重复表中实现联动下拉列表框就会有问题。即当你更改重复表中的某一行上级下拉列表框时,所有行的下级下拉列表框的选项都会变成相同的内容。产生这种问题的原因是重复表中的所有行的下级下拉列表框都采用同一个辅助数据源,而任何一个上级下拉列表框变动时都会改变这个辅助数据源。要想解决这个问题,就必须为每个下级下拉列表框设置不同的数据源,笔者在infopathdev博客上发现一篇文章(参考资料[3]),从中找到了解决方案。

解决方案的思路是这样的:在重复表中添加一个重复的域,将这个域作为下级下拉列表框的数据源;当同一行的上级下拉列表框变动时,程序将更新这个重复域。由于重复表的每行都有本行的重复域,所以每行的下级下拉列表框的数据源是不同的,不会相互影响。下面演示详细实现步骤。

第一步,准备数据源列表。

本例需要一个原始数据源,仍然使用上篇文章中创建的SharePoint列表——Cities。重复表中的重复域的值是它的一个子集,是根据上级下拉列表框的值过滤得来的。

第二步,设计InfoPath表单。

1.表单上要放置一个重复表,重复表中放置两个下拉列表框ddlb1和ddlb2,在主数据源中添加一个重复域ddlb2Source,如下图。



2.确认域ddlb2Source的属性框中选择“重复”。



3.下拉列表框ddlb2的列表框项选择“在表单数据源中查找值”,项选择为“/my:myFields/my:group1/my:group2/my:ddlb2Source”。
  


4.下拉列表框ddlb1属性的“浏览器表单”页,确认回发设置为“始终”。

5.创建数据连接,指向SharePoint列表Cities,方法参见上一篇文章。

6.确认“启用浏览器兼容性功能”,确认安全级别为“完全信任”,方法参见上一篇文章。

抱歉!评论已关闭.