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里面可以对总金额进行计算,但这一种方法,在填写报销单时总金额不能及时显示的,不知其他兄弟有何高见,有经验的兄弟可以与大家分享一下,关于代码应该在哪里写会更好一点。

 上面还有一个关于序号的问题,目前这个序号问题没有实现,技术实现方案:我想获取添加与删除的事件,当添加与删除的时,通过代码循环设置序号的,但目前不能触发这两个事件,不过网上有这样一篇博客,但是他的处理有点缺陷,如果添加几个后,删除其中一个,序号就不连续了。针对这个问题,兄弟们有何高见呢?

 

 

posted @ 2012-06-12 16:46  @@@一统@@@  阅读(1851)  评论(4编辑  收藏  举报