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

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

chukudan.xsl:

 

>


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

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

物流系统中使用XML实现通用WEB报表打印          '是否取得了单据
物流系统中使用XML实现通用WEB报表打印
            If billInfoXml <> Nothing Then
物流系统中使用XML实现通用WEB报表打印
物流系统中使用XML实现通用WEB报表打印                billInfoDoc.LoadXml(billInfoXml)
物流系统中使用XML实现通用WEB报表打印                
'billInfoDoc.LoadXml("http://111.111.111.111/stockmg/test.xsl")
物流系统中使用XML实现通用WEB报表打印
                billTrans.Load(billFormatXmlUrl)
物流系统中使用XML实现通用WEB报表打印
物流系统中使用XML实现通用WEB报表打印                billXmlWr.Formatting 
= System.Xml.Formatting.Indented
物流系统中使用XML实现通用WEB报表打印                billXmlWr.Indentation 
= 4
物流系统中使用XML实现通用WEB报表打印                billXmlWr.IndentChar 
= " "
物流系统中使用XML实现通用WEB报表打印
物流系统中使用XML实现通用WEB报表打印                billTrans.Transform(billNav, 
Nothing, billXmlWr, Nothing)
物流系统中使用XML实现通用WEB报表打印                billXmlWr.Flush()
物流系统中使用XML实现通用WEB报表打印
物流系统中使用XML实现通用WEB报表打印            
End If
物流系统中使用XML实现通用WEB报表打印
物流系统中使用XML实现通用WEB报表打印


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

物流系统中使用XML实现通用WEB报表打印 parent.frames.frmhidPrint.parent.frames.frmhidPrint.print1.SetXml(xmlResult); parent.frames.frmhidPrint.parent.frames.frmhidPrint.print1.PrintAct();

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

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

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

效果如下:
物流系统中使用XML实现通用WEB报表打印
   

相关文章:

  • 2021-12-11
  • 2022-12-23
  • 2022-12-23
  • 2021-12-23
  • 2021-07-02
  • 2021-06-29
  • 2022-12-23
猜你喜欢
  • 2022-12-23
  • 2021-11-18
  • 2021-06-22
  • 2022-01-06
  • 2021-11-18
  • 2021-11-18
相关资源
相似解决方案