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

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

chukudan.xsl:

<?xml version="1.0" encoding="GB2312"?><xsl:stylesheet version="1.0"  xmlns:xsl="http://www.w3.org/1999/XSL/Transform">      <xsl:template match="Bill">      <root> <pagesetting>  <landscape>false</landscape>  <paperkind>Custom</paperkind>  <paperwidth>800</paperwidth>  <paperheight>600</paperheight>  <paperleft>0</paperleft>  <paperight>0</paperight>  <papetop>0</papetop>  <papebottom>0</papebottom> </pagesetting> <reporttable>      <bill x="55" y="19" border="0" bordercolor="white" maxlines="6">  <xsl:for-each select="BillMaster">   <toptable width="743">    <tr height="20"><td width="118"  align="right"  fontsize="10" fontname="宋体" fontcolor="black" b="true" i="false" u="false" bgcolor="white">车次号:</td><td width="449"  align="right"  fontsize="10" fontname="宋体" fontcolor="black" b="true" i="false" u="false" bgcolor="White"><xsl:value-of select="SERIAL_NO" /></td>     <td width="35"  align="right"  fontsize="10" fontname="宋体" fontcolor="black" b="true" i="false" u="false" bgcolor="white"></td>     <td width="138"  align="right"  fontsize="10" fontname="宋体" fontcolor="black" b="true" i="false" u="false" bgcolor="white"></td>    </tr>      </toptable>   </xsl:for-each>   <detailtable width="373">   <xsl:for-each select="BillDetail">       <tr height="33">     <td width="90" align="right"  fontsize="10" fontname="宋体" fontcolor="black" b="true" i="false" u="false" bgcolor="White">     <xsl:value-of select="BILL_NO" />     </td>     <td width="173" align="right"  fontsize="10" fontname="宋体" fontcolor="black" b="true" i="false" u="false" bgcolor="white">     <xsl:value-of select="PROD_MODEL_2" /></td>     <td width="55" align="right"  fontsize="10" fontname="宋体" fontcolor="black" b="true" i="false" u="false" bgcolor="White">     <xsl:value-of select="PROD_NUM" /></td>     <td width="55" align="right"  fontsize="10" fontname="宋体" fontcolor="black" b="true" i="false" u="false" bgcolor="white">     <xsl:value-of select="PIECE_NUM" /></td>              </tr>        </xsl:for-each>   </detailtable>  <mastertable width="370">   <xsl:for-each select="BillMaster">    <tr height="33">     <td width="90" align="right"  fontsize="10" fontname="宋体" fontcolor="black" b="true" i="false" u="false" bgcolor="White">     </td>     <td width="280" align="right"  fontsize="10" fontname="宋体" fontcolor="black" b="true" i="false" u="false" bgcolor="white">     <xsl:value-of select="ADDRESS" />     </td>    </tr>    <tr height="33">     <td width="90" align="right"  fontsize="10" fontname="宋体" fontcolor="black" b="true" i="false" u="false" bgcolor="white">     </td>     <td width="90" align="right"  fontsize="10" fontname="宋体" fontcolor="black" b="true" i="false" u="false" bgcolor="White">     <xsl:value-of select="CONTACT_PERSON" /></td>     <td width="70" align="right"  fontsize="10" fontname="宋体" fontcolor="black" b="true" i="false" u="false" bgcolor="white">     </td>     <td width="120" align="right"  fontsize="10" fontname="宋体" fontcolor="black" b="true" i="false" u="false" bgcolor="White">     <xsl:value-of select="CONTACT_PHONE" /></td>    </tr>    <tr height="33">             <td width="90" align="right"  fontsize="10" fontname="宋体" fontcolor="black" b="true" i="false" u="false" bgcolor="White">     </td>     <td width="280" align="right"  fontsize="10" fontname="宋体" fontcolor="black" b="true" i="false" u="false" bgcolor="white">     <xsl:value-of select="DRIVER_UNIT" /></td>    </tr>    <tr height="33">     <td width="90" align="right"  fontsize="10" fontname="宋体" fontcolor="black" b="true" i="false" u="false" bgcolor="white">     </td>     <td width="90" align="right"  fontsize="10" fontname="宋体" fontcolor="black" b="true" i="false" u="false" bgcolor="white">     <xsl:value-of select="DRIVER_NO" /></td>     <td width="70" align="right"  fontsize="10" fontname="宋体" fontcolor="black" b="true" i="false" u="false" bgcolor="white">     </td>     <td width="120" align="right"  fontsize="10" fontname="宋体" fontcolor="black" b="true" i="false" u="false" bgcolor="white">     <xsl:value-of select="DRIVER_PERSON" /></td>    </tr>    <tr height="33">     <td width="90" align="right"  fontsize="10" fontname="宋体" fontcolor="black" b="true" i="false" u="false" bgcolor="white">     </td>     <td width="90" align="right"  fontsize="10" fontname="宋体" fontcolor="black" b="true" i="false" u="false" bgcolor="white">     <xsl:value-of select="CAR_MODEL" />     </td>     <td width="70" align="right"  fontsize="10" fontname="宋体" fontcolor="black" b="true" i="false" u="false" bgcolor="white">     </td>     <td width="120" align="right"  fontsize="10" fontname="宋体" fontcolor="black" b="true" i="false" u="false" bgcolor="white"></td>    </tr>    <tr height="33">     <td width="90"  align="right"  fontsize="10" fontname="宋体" fontcolor="black" b="true" i="false" u="false" bgcolor="white">     </td>     <td width="280" align="right"  fontsize="10" fontname="宋体" fontcolor="black" b="true" i="false" u="false" bgcolor="white">     <xsl:value-of select="COME_TO" /></td>    </tr>   </xsl:for-each>   </mastertable>     <foottable width="743">   <xsl:for-each select="BillMaster">    <tr height="35">     <td width="90" align="right"  fontsize="10" fontname="宋体" fontcolor="black" b="true" i="false" u="false" bgcolor="White"></td>     <td width="173" align="right"  fontsize="10" fontname="宋体" fontcolor="black" b="true" i="false" u="false" bgcolor="white"></td>     <td width="55" align="right"  fontsize="10" fontname="宋体" fontcolor="black" b="true" i="false" u="false" bgcolor="White"></td>     <td width="55" align="right"  fontsize="10" fontname="宋体" fontcolor="black" b="true" i="false" u="false" bgcolor="white"></td>                   <td width="90"  align="right"  fontsize="10" fontname="宋体" fontcolor="black" b="true" i="false" u="false" bgcolor="white">     </td>     <td width="280" align="right"  fontsize="10" fontname="宋体" fontcolor="black" b="true" i="false" u="false" bgcolor="white">     <xsl:value-of select="REMARK" /></td>    </tr>     </xsl:for-each>      </foottable>            </bill>   </reporttable></root>        </xsl:template> </xsl:stylesheet>

其中,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); //SetMessage(xmlResult);  parent.frames.frmhidPrint.parent.frames.frmhidPrint.print1.PrintAct();

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

以上就是利用XML实现通用WEB报表打印实际使用中的例子的内容,更多相关内容请关注PHP中文网(www.php.cn)!

更多相关文章

  1. JavaScript 创意卡通滑杆拖动控件
  2. 条码读取控件Dynamsoft Barcode Reader v8.1全新上线!添加了对MSI
  3. 在excel 中添加表单控件
  4. 当CSS遇上表单控件
  5. [置顶] JQuery datatables 使用Fixedcolumns固定列控件
  6. 在jQuery返回的HTML中找到控件
  7. jquery中的Datepicker控件如何默认显示日期
  8. 发布一个基于jquery的无限层级下拉控件
  9. JQUERY中做表单验证,谁有带时间的日期选择控件?

随机推荐

  1. Golang可以用来做什么
  2. golint的简易使用方法
  3. golang读取文件是否存在
  4. Golang接口哪里好
  5. golang 嵌入乱码怎么办
  6. Golang格式化符号%b是什么意思
  7. Golang反射为什么慢
  8. golang反射用于什么场景
  9. Golang底层是什么语言
  10. golang和go是什么关系