绝对绿茶 发表于 2015-9-27 08:14:28

SharePoint 2010 + Infopath 2010 VSTA + WF + Timer Job + BI 之 报销单实例系列---------创建报

  关于Infopath的详细操作步骤这里不在详细介绍,如果想更深入的了解Infopath如何使用,请下载视频教程(英文)自己学习。
  根据上一篇的介绍,先把报销单完成,完成后的报销单击如图所示


  下面介绍一下详细开发步骤:
  第一步:创建报销人,采用默认值,用到了内置函数

  第二步:创建年月,同样要用到内置函数,函数的详细用法在图上会说明的

  这是两个比较特殊的字段,做了详细说明,还有一个字段是 报销金额,这个字段是字符类型,因为这个值是通过VSTA编程计算得到的,目前情况下只是字符,如果是数据会提示错误,目前没有找到合适的解决办法,代码会在后面写出来的,如果有好方法的兄弟可以给点指点。
  第三步:配制VSTA编程的代码
  选择---文件----窗体选项,会弹出如下窗体

  第四步:打开编码窗体,添加代码,计算报销金额的值。

  第五步:编写代码,并计算总金额

  主要代码介绍



public void 金额_Changed(object sender, XmlEventArgs e)
{
XPathNavigator getData = this.CreateNavigator();
XPathNavigator expensiveGroup = getData.SelectSingleNode("/my:ExpensiveReport/my:Expensive",NamespaceManager);
XPathNodeIterator expensiveAmount = expensiveGroup.SelectDescendants("ExpensiveDetail", expensiveGroup.NamespaceURI, false);
double amountTotal = 0;
string amountValue = "";
foreach (XPathNavigator amount in expensiveAmount) //遍历金额字段
            {
amountValue = amount.SelectSingleNode("my:金额", NamespaceManager).Value;
if (!string.IsNullOrEmpty(amountValue))
{
amountTotal += double.Parse(amountValue);
}
}
//设置报销金额的值
//通过查找资料发现这里只能设置String的值,如果设置Double类型会出错的,目前没有办法解决设置数字类型的值
//如果有知道的兄弟,请回复一下,不胜感激
getData.SelectSingleNode("/my:ExpensiveReport/my:报销金额", NamespaceManager).SetValue(amountTotal.ToString());
  就这样一个报销单就完成了,目前在网上看到了别人建议,不要把代码写到报销单里面,这样维护与管理比较难,但是没有看到有关解决方法,只提出了建议,我知道的一种计算方法是在Workflow里面可以对总金额进行计算,但这一种方法,在填写报销单时总金额不能及时显示的,不知其他兄弟有何高见,有经验的兄弟可以与大家分享一下,关于代码应该在哪里写会更好一点。
  上面还有一个关于序号的问题,目前这个序号问题没有实现,技术实现方案:我想获取添加与删除的事件,当添加与删除的时,通过代码循环设置序号的,但目前不能触发这两个事件,不过网上有这样一篇博客,但是他的处理有点缺陷,如果添加几个后,删除其中一个,序号就不连续了。针对这个问题,兄弟们有何高见呢?
  
  
页: [1]
查看完整版本: SharePoint 2010 + Infopath 2010 VSTA + WF + Timer Job + BI 之 报销单实例系列---------创建报