通过编程方式在InfoPath 2010表单的下拉框修改事件中获取数据

一个简单的例子,包括一段简短的代码,在InfoPath 2010表单中下拉框的修改事件里从一个数据源获取数据。

表单

样例表单本身很简单,只有两个控件,如下图所示:

通过编程方式在InfoPath 2010表单的下拉框修改事件中获取数据_第1张图片

在mydropdown下拉框属性中,添加几个值,为将要获取的SharePoint列表中已有的几个列表项的ID。

通过编程方式在InfoPath 2010表单的下拉框修改事件中获取数据_第2张图片

另外,在浏览器表单选项卡中,设置始终获取数据。以便在下拉框值发生修改时,自动获取数据。

通过编程方式在InfoPath 2010表单的下拉框修改事件中获取数据_第3张图片

设置好表单布局后,点击功能区“数据”选项卡中的“数据连接”,设置一个数据源。

通过编程方式在InfoPath 2010表单的下拉框修改事件中获取数据_第4张图片

在弹出的“数据连接”对话框中,点击“添加...”。打开数据连接向导对话框。选择“接收数据”。

通过编程方式在InfoPath 2010表单的下拉框修改事件中获取数据_第5张图片

下一步。选择“SharePoint库或列表”

通过编程方式在InfoPath 2010表单的下拉框修改事件中获取数据_第6张图片

下一步。输入SharePoint网站地址。

通过编程方式在InfoPath 2010表单的下拉框修改事件中获取数据_第7张图片

下一步。选择需要连接的列表。

通过编程方式在InfoPath 2010表单的下拉框修改事件中获取数据_第8张图片

下一步。选择域。在下面的代码中,我们会用到Title,所以这里把它选中。

通过编程方式在InfoPath 2010表单的下拉框修改事件中获取数据_第9张图片

一路下一步,直到完成该向导。将我们的数据连接命名为“MyDATASOURCE”。

选中下拉框控件,点击功能区“开发工具”选项卡下控件事件组中的“Changed事件”。

通过编程方式在InfoPath 2010表单的下拉框修改事件中获取数据_第10张图片

将打开VSTA集成开发环境。

代码

下面的代码中,InternalStartup()方法用于注册下拉框的修改事件,mydropdown_Changed()方法用于实际的从数据源获取数据...

“MyDATASOURCE”是为了获取表单域field1的值,也就是来自SharePoint列表数据源(MyDATASOURCE)的SharePoint列表项标题。

通过Web服务传递给数据源的参数是列表项ID,由下拉框的当前值决定。

using Microsoft.Office.InfoPath;
using System;
using System.Xml;
using System.Xml.XPath;

namespace Getdatanamespace
{
    public partial class FormCode
    {

        // 注意: 以下是 Microsoft InfoPath 所需的过程。
        // 可以使用 Microsoft InfoPath 对其进行修改。
        public void InternalStartup()
        {
            EventManager.XmlEvents["/my:myFields/my:mydropdown"].Changed += new XmlChangedEventHandler(mydropdown_Changed);
        }

        public void mydropdown_Changed(object sender, XmlEventArgs e)
        {
            // 在此处编写代码,用于更改主数据源。
            XPathNavigator form = MainDataSource.CreateNavigator();

            // 为Web服务调用和查询连接准备参数
            // 发送ID作为调用web服务的参数,用于访问该数据源
            DataSources["MyDATASOURCE"].CreateNavigator().SelectSingleNode("dfs:myFields/dfs:queryFields/q:SharePointListItem_RW/q:ID",NamespaceManager).SetValue(e.NewValue); 
            DataSources["MyDATASOURCE"].QueryConnection.Execute();

            // 基于web服务的响应创建一个 navigator
            XPathNavigator resultnav = DataSources["MyDATASOURCE"].CreateNavigator();

            // 用web服务响应中的数据设置字段的值
            XPathNavigator Field1 = form.SelectSingleNode("/my:myFields/my:field1", NamespaceManager);
            Field1.SetValue(resultnav.SelectSingleNode("/dfs:myFields/dfs:dataFields/d:SharePointListItem_RW/d:Title",NamespaceManager).Value);

        }
    }
}

运行

代码编写完成后,可以直接通过F5运行,将自动打开表单预览界面。

通过编程方式在InfoPath 2010表单的下拉框修改事件中获取数据_第11张图片

测试无误后,就可以发布到SharePoint表单库中了。

点击左上角的“文件”选项卡,打开后台视图。选择“发布”下的“SharePoint服务器”

通过编程方式在InfoPath 2010表单的下拉框修改事件中获取数据_第12张图片

跟随向导,一步步的进行就可以了。本例中,我们选择发布到表单库。

通过编程方式在InfoPath 2010表单的下拉框修改事件中获取数据_第13张图片

完成!点击“在浏览器中打开此表单”。

通过编程方式在InfoPath 2010表单的下拉框修改事件中获取数据_第14张图片

在SharePoint中运行的样子:

通过编程方式在InfoPath 2010表单的下拉框修改事件中获取数据_第15张图片

 

参考资料

Infopath 2010 form drop-down list change event get data programmatically

你可能感兴趣的:(Path)