推薦:對XML數據使用XMLConvertXML文件中的所有數據都以字符串來存儲。當一個程序載入XML文件時,通常需要將數據轉換為更加適合程序的類型。
例如,假設訂單裝運日期存在一個XML文件里,則使用該文件的程序需要將字符串表示
一、前言
ASP在電子商務上應用廣泛,報表的處理又有一些麻煩。本文介紹了在ASP中利用本人寫的Report Server Page腳本解釋器實現報表的顯示、打印。
二、準備工作
(1)安裝Visual Reprort Design軟件
Visual Report Design是本人寫的一個免費的報表設計器,程序的發行只需要安裝一個控件即可。
(2)設計報表
通過Visual Report Design 的可視化界面可以生成報表的腳本:mxb.rsp。
三、實現報表的打印、顯示
下面是調用的文檔:
以下為引用的內容:
printmx.asp <%Option Explicit%> <% dim ReportName,ret dim ReportAtl dim name set ReportAtl=Session("ReportAtl") ReportName=Server.MapPath("mxb.rsp") ret=reportatl.XMLToVBS(ReportName) if ret=-1 then response.write reportatl.ErrorMsg response.end end if
ReportName=Server.MapPath("mxb.vbs") ret=reportatl.DoScript(ReportName) if ret=-1 then response.write reportatl.ErrorMsg set ReportAtl=nothing response.end end if set ReportAtl=nothing %> <html> <OBJECT id=reportatl classid="clsid:D3F064E5-F4C0-4C52-9E7F-263D96B7EA11" codebase="Report.cab#version=1,0,0,1"> </OBJECT> <script language=vbscript> dim ret ret=reportatl.DoPrintReport("mxb.zcg") if ret=-1 then msgbox reportatl.ErrorMsg end if </script> </html> 用Visual Report Design 產生的報表腳本mxb.rsp: <?xml version="1.0" encoding="GB2312" ?> <!DOCTYPE report SYSTEM "print_report.dtd" > <report name="報表"> <report_script> dim rs,con,sql,lsh dim temp set con =CreateObject("ADODB.Connection") con.ConnectionString = "DBQ=c:\report\demo\asp\report.mdb;DRIVER={Microsoft Access Driver (*.mdb)};" con.open Set rs =CreateObject("ADODB.Recordset") sql="SELECT * FROM cj,student where cj.id=student.id " rs.open sql,con,1,3 </report_script> <report_head height="12"> <text name="vfptext" top="4" left="76" width="26" height="5" font_name="宋體" font_size="14" font_weight="700" font_italic="0" font_underline="0" > 成績明細表 </text> </report_head> <page_head height="6"> <line name="vfpline" top="0" left="9" width="178" height="0" weight="131072"> </line> <line name="vfpline" top="6" left="9" width="178" height="0" weight="131072"> </line> <text name="vfptext" top="2" left="18" width="6" height="3" font_name="宋體" font_size="9" font_weight="700" font_italic="0" font_underline="0" > 姓名 </text> <text name="vfptext" top="2" left="46" width="6" height="3" font_name="宋體" font_size="9" font_weight="700" font_italic="0" font_underline="0" > 語文 </text> <text name="vfptext" top="2" left="72" width="6" height="3" font_name="宋體" font_size="9" font_weight="700" font_italic="0" font_underline="0" > 數學 </text> <text name="vfptext" top="2" left="99" width="6" height="3" font_name="宋體" font_size="9" font_weight="700" font_italic="0" font_underline="0" > 英語 </text> <text name="vfptext" top="2" left="162" width="6" height="3" font_name="宋體" font_size="9" font_weight="700" font_italic="0" font_underline="0" > 合計 </text> <text name="vfptext" top="2" left="130" width="6" height="3" font_name="宋體" font_size="9" font_weight="700" font_italic="0" font_underline="0" > 平均 </text> </page_head> <page_body height="8"> <text name="vfptext" top="2" left="15" width="25" height="4" font_name="宋體" font_size="9" font_weight="100" font_italic="0" font_underline="0" > <report_script> Report.Write cstr(rs("xm")) </report_script> </text> <text name="vfptext" top="2" left="45" width="18" height="4" font_name="宋體" font_size="9" font_weight="100" font_italic="0" font_underline="0" > <report_script> Report.Write cstr(rs("yw")) </report_script> </text> <text name="vfptext" top="2" left="71" width="18" height="4" font_name="宋體" font_size="9" font_weight="100" font_italic="0" font_underline="0" > <report_script> Report.Write cstr(rs("sx")) </report_script> </text> <text name="vfptext" top="2" left="98" width="18" height="4" font_name="宋體" font_size="9" font_weight="100" font_italic="0" font_underline="0" > <report_script> Report.Write cstr(rs("yy")) </report_script> </text> <text name="vfptext" top="2" left="130" width="18" height="4" font_name="宋體" font_size="9" font_weight="100" font_italic="0" font_underline="0" > <report_script> Report.Write cstr((rs("yw") rs("sx") rs("yy"))/3) </report_script> </text> <text name="vfptext" top="2" left="162" width="18" height="4" font_name="宋體" font_size="9" font_weight="100" font_italic="0" font_underline="0" > <report_script> Report.Write cstr(rs("yw") rs("sx") rs("yy")) </report_script> </text> </page_body> <page_foot height="7"> <text name="vfptext" top="2" left="12" width="13" height="3" font_name="宋體" font_size="9" font_weight="100" font_italic="0" font_underline="0" > <report_script> report.write "打印日期:" formatdatetime(date(),1) </report_script> </text> <text name="vfptext" top="2" left="137" width="50" height="3" font_name="宋體" font_size="9" font_weight="100" font_italic="0" font_underline="0" > 共%Pages%頁,第%Page%頁 </text> <line name="vfpline" top="0" left="8" width="178" height="0" weight="131072"> </line> </page_foot> <report_script> do while not rs.eof page_body() rs.movenext loop rs.close set rs=nothing con.close set con=nothing </report_script> </report>
|
分享:XMLHTTP對象封裝技術Ajax技術的實現主要依賴于xmlhttprequest,但我們在調用其來進行異步數據的傳輸時,由于xmlhttp是個短線過程(處理事件完成后就銷毀)如果不對該對象進行包裝處理的話,就不得不在需要調用的地