有心栽花花不开,无心插柳柳成荫

人生不易,自得其乐

导航

物流系统中使用XML实现通用WEB报表打印

Posted on 2006-03-23 16:28  薛冰  阅读(2340)  评论(9编辑  收藏  举报

最近做的一个B/S项目,在打印时采用了在IE中嵌入.net winform控件和XML结合的方式(参见http://www.yesky.com/20030214/1652186.shtml),在实际应用过程中,有一些心得,和大家分享。

一.使用通用模版格式化XML文件
系统中共用到了三种单据,分别为出库单,入库单,送货单,因此,定义三个模版文件,以出库单为例,格式如下:

chukudan.xsl:

 


解释一下:其中,toptable是表头,detailtable是表格左边的产品明细,mastertable是表格右边的运输信息等,foottable是最下面制表人等信息。

(二).在asp.net页面中,将查询出的结果作如下转换 

          '是否取得了单据
            If billInfoXml <> Nothing Then

                billInfoDoc.LoadXml(billInfoXml)
                
'billInfoDoc.LoadXml("http://111.111.111.111/stockmg/test.xsl")
                billTrans.Load(billFormatXmlUrl)

                billXmlWr.Formatting 
= System.Xml.Formatting.Indented
                billXmlWr.Indentation 
= 4
                billXmlWr.IndentChar 
= " "

                billTrans.Transform(billNav, 
Nothing, billXmlWr, Nothing)
                billXmlWr.Flush()

            
End If


三.返回的信息用javascript代码加载到打印控件:

 parent.frames.frmhidPrint.parent.frames.frmhidPrint.print1.SetXml(xmlResult); parent.frames.frmhidPrint.parent.frames.frmhidPrint.print1.PrintAct();

注意,这里调用打印控件用了parent.frames....这是为了节省每次打开页面时加载打印控件的时间,使用了一个框架网页,把打印控件放在一个单独的页面中,从而不需每次加载。

四.打印纸张大小的控制
开始采用的是在打印控件中读取上面的XML文件设定的纸张大小,总是没有反应,后来发现,对于打印机的纸张大小控制,程序并不是总是有效的。可靠的方法是在打印机的纸张类型中添加本系统需要的纸张类型,程序中直接调用这个纸张,使用中没有再出现问题。

希望和各位多多交流,不吝指正。

效果如下: