最近几天接触微软的 InfoPath 表单工具,结合VS 使用,遇到的一些问题与解决方法,记录一下,百度上的内容很少,或许我根本不知道咋搜,所有也留一个网页帮助自己使用当然使用的时候碰到了好几个坑:
限制: infoPath 只支持 VS 2012 这个版本的,我安得 2013 不能用哎
在 ‘开发工具’ --‘代码编译器’ 会让你安装一个 vs2012 Tools 必须安装,因为要用这个功能开发
就是 infoPath 表单文件 不要直接打开 会告诉你签名啥的, 不要慌 关了,右键点击设计一定要
vs中 加断点,提示断点无法命中,注意保存infoPath 的时候 一定不要出现 中文,原因在这里。
页面元素:
像微软的东西大概使用方法都是差不多的,快捷键啥的,新建文件就不说了,按部就班的点就可以了。表单工具吗,首先就是创建表单,创建一些控件,就像winForm一样使用,在表单上点击产生此对象,按钮,下拉框,文本框这类的。
控件生成之后 就可以右键点击控件先说
文本框属性: 默认值、文本框大小、文本框类型、是否为空 、、、这样一些列的设置。
更改控件类型: 修改控件类型 如变成多选按钮啥的。
更改绑定: 这个就可以理解为绑定一个域元素,也就相当于一个公共变量。 软件右侧会出现 域 操作窗口,里面包括当前 表单 myFields 对应的 域元素。
域元素:
然后就是域元素的, 其中的域元素可以拖拽到表单中生成对应类型的 控件,当然可以把 所有 域元素 放到myFields文件下,也可以像这样分组放开, 右键myfields 可以添加 分组或者控件。本人还是比较建议直接放到myFields 文件下,这样以后使用会简单的多,就是会看起来比较乱。
当这是右键域元素时:我感觉最重要的3个点就是 规则,属性,复制Xpath,
规则:就是制定 域控件中的 逻辑判断,比如值不能大于多少啥的。
属性:这个则跟之前 右键控件 基本相同。
复制Xpath: 这个东西很简单 ,你点击一下然后 复制在文本上,你就可以看出是个路径:/my:myFields/my:UserInfo/my:Submitter.Name 也就是以后再vs中 获取域元素时使用的路径(仅限于多层组的情况下)
我使用过的控件 感觉有一些注意的就是 :
下拉列表:需要从下拉列表属性 中设置一下 从外部数据源获取,选择添加 ,选sql server,之后就一直点,然后就是 配置值跟 显示名称。
按钮: 一般情况下 的控件事件都是 change 事件, 按钮是单机事件需要 在按钮属性中 编辑代码,然后会在vs中自动生成。
重复表: 这个一边用在 添加多条数据, 会自动生成一个大组,包一小组,获取 值使用foreach,还是获取节点到 小组 ,
XPathNodeIterator NodeIter = this.MainDataSource.CreateNavigator().Select("/my:myFields/my:组1/my:组2", this.NamespaceManager);
然后便利这个值
foreach (XPathNavigator myf in NodeIter) { XPathNavigator n1 = myf.SelectSingleNode("my:域1", NamespaceManager); XPathNavigator n2 = myf.SelectSingleNode("my:域2", NamespaceManager); XPathNavigator n3 = myf.SelectSingleNode("my:域3", NamespaceManager); }
注意 类型,便利的值, 直接填my: 域元素。 这时有个疑惑不过加了断点就没问题了, 当增加多个表行 之后 获取 元素值,都在myf 中 ,便利一次为一行。
下拉列表级联
前一阵子涉及到下拉列表级联问题,目前我本人 学会两种方式,能完成类似省份,市县 的这种关系。
第一种: 用 页面中下拉列表属性中的 数据库数据源 中的“项”来 添加数据筛选, 第一list 为主,他的值作为第二个list 筛选的依据,不过 这样第二个列表的value和Key 都会只能选择 筛选项的 值。
第二种:就是用代码了 通过list 的change 事件 来获取当前list的 值, 再获取list2 的 Navigator 对象 ,赋值这样。看代码一下吧
public void Trusit_2E_abilityType_Changed(object sender, XmlEventArgs e) { // 在此处编写代码,用于更改主数据源。
获取list 2 的对象,然后之set为“” //从数据库取得列表 AdoQueryConnection myAdoQueryConn = (AdoQueryConnection)(this.DataConnections["表名"]); myAdoQueryConn.Command = " select id,name from 表名where parent='" + e.NewValue + "' order by name "; myAdoQueryConn.Execute(); }
第二种 就有个 疑问就是 他如何付给list2 值 的,一直不太清楚