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

最近做的一个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文件设定的纸张大小,总是没有反应,后来发现,对于打印机的纸张大小控制,程序并不是总是有效的。可靠的方法是在打印机的纸张类型中添加本系统需要的纸张类型,程序中直接调用这个纸张,使用中没有再出现问题。

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

效果如下:
物流系统中使用XML实现通用WEB报表打印_第1张图片
   

你可能感兴趣的:(web报表)