利用XML实现通用WEB报表打印实际使用中的例子

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

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
 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.资讯内容不构成投资建议,投资者应独立决策并自行承担风险
2.本文版权归属原作所有,仅代表作者本人观点,不代表本站的观点或立场
上一篇:php获取远程图片并下载保存到本地的方法分析 下一篇:读取XML为行记录

相关资讯