小弟试做了一个B/S架构的医院管理系统,但卡在了发票套打上面,
这个打印不需要预览而直接打印,而且打印也并非A4的纸,以前试用过水晶报表和grid++report,
但结果都不是很理想,水晶报表的打印只能在服务器上进行( PrintToPrinter() );
并且对于页面大小设置来说相当困难。
小弟在此请求哪位大虾能给一个解决B/S模式下无预览发票套打解决方案
分虽少了点,小弟在此感激不尽
3Q
这个打印不需要预览而直接打印,而且打印也并非A4的纸,以前试用过水晶报表和grid++report,
但结果都不是很理想,水晶报表的打印只能在服务器上进行( PrintToPrinter() );
并且对于页面大小设置来说相当困难。
小弟在此请求哪位大虾能给一个解决B/S模式下无预览发票套打解决方案
分虽少了点,小弟在此感激不尽
3Q
先加载要打印的页面。然后在页面加载完后,用javascript打印页面,打印完后用javascipt关闭打印页面。
至于不用预览,可以把要打印的页面放在一frame中。然后把这个frame隐藏就行了。
谢谢了
之前看到一个产品使用客户端excel来实现类似的功能,挺巧妙的
这个控件是要收费的,不过你只需参考打印部分就行了,不用他的控件
http://218.28.143.234/report/default.aspx?reportName=交叉表_1997年产品销售额.cr看这个页面上的打印按钮和打印预览按钮,找到里面的脚本看看。
之前用水晶报表开发的
在开发报表做了页面设置,但是就是不知道怎么在打印机上设置才能起作用
用的水晶报表服务器打印printToPrinter`
现在主要问题是卡在了打印滚纸上面
每次都不是按照自定义纸张大小滚的纸
自定义纸张大小为7.5CM* 10.1CM
麻烦请教哪位大虾能给个详细点的说明·
到底是怎么样设置才能按照自定义纸张大小滚纸
打印的是连票,就是打一张撕一张那种
谢谢了
分不够的话小弟在发个给分
谢谢了
3Q
最佳实践:AcriveX,可采用C++或delphi开发。
下面是两种从asp.net导出的方法,仅供参考!1、将整个html全部输出execl
Response.Clear();
Response.Buffer= true;
Response.AppendHeader("Content-Disposition","attachment;filename="+DateTime.Now.ToString ("yyyyMMdd")+".xls");
Response.ContentEncoding=System.Text.Encoding.UTF8;
Response.ContentType = "application/vnd.ms-excel";
this.EnableViewState = false;
2、将DataGrid控件中的数据导出Execl
System.Web.UI.Control ctl=this.DataGrid1;
//DataGrid1是你在窗体中拖放的控件
HttpContext.Current.Response.AppendHeader("Content-Disposition","attachment;filename=Excel.xls");
HttpContext.Current.Response.Charset ="UTF-8";
HttpContext.Current.Response.ContentEncoding =System.Text.Encoding.Default;
HttpContext.Current.Response.ContentType ="application/ms-excel";
ctl.Page.EnableViewState =false;
System.IO.StringWriter tw = new System.IO.StringWriter() ;
System.Web.UI.HtmlTextWriter hw = new System.Web.UI.HtmlTextWriter (tw);
ctl.RenderControl(hw);
HttpContext.Current.Response.Write(tw.ToString());
HttpContext.Current.Response.End();
3、将DataSet中的数据导出Execl
public void CreateExcel(DataSet ds,string FileName)
{
HttpResponse resp;
resp = Page.Response;
resp.ContentEncoding = System.Text.Encoding.GetEncoding("GB2312");
resp.AppendHeader("Content-Disposition", "attachment;filename="+FileName);
string colHeaders= "", ls_item="";
//定义表对象与行对象,同时用DataSet对其值进行初始化
DataTable dt=ds.Tables[0];
DataRow[] myRow=dt.Select();//可以类似dt.Select("id>10")之形式达到数据筛选目的
int i=0;
int cl=dt.Columns.Count;
//取得数据表各列标题,各标题之间以t分割,最后一个列标题后加回车符
for(i=0;i {
if(i==(cl-1))//最后一列,加n
{
colHeaders +=dt.Columns[i].Caption.ToString() +"n";
}
else
{
colHeaders+=dt.Columns[i].Caption.ToString()+"t";
}
}
resp.Write(colHeaders);
//向HTTP输出流中写入取得的数据信息
//逐行处理数据
foreach(DataRow row in myRow)
{
//当前行数据写入HTTP输出流,并且置空ls_item以便下行数据
for(i=0;i {
if(i==(cl-1))//最后一列,加n
{
ls_item +=row[i].ToString()+"n";
}
else
{
ls_item+=row[i].ToString()+"t";
}
}
resp.Write(ls_item);
ls_item="";
}
resp.End();
}
该文章转载自德仔工作室:http://www.dezai.cn/Article_Show.asp?ArticleID=31445C#中,打印panel
该文章转载自德仔工作室:http://www.dezai.cn/Article_Show.asp?ArticleID=17969 Asp.net 水晶报表之打印和导出格式
该文章转载自德仔工作室:http://www.dezai.cn/Article_Show.asp?ArticleID=30670 ASP.NET 页面打印与预览
该文章转载自德仔工作室:http://www.dezai.cn/Article_Show.asp?ArticleID=31368 网页的横向打印的三种方案
该文章转载自德仔工作室:http://www.dezai.cn/Article_Show.asp?ArticleID=28333 打印网页中定义的部分内容
该文章转载自德仔工作室:http://www.dezai.cn/Article_Show.asp?ArticleID=22916 Web页面打印技术
该文章转载自德仔工作室:http://www.dezai.cn/Article_Show.asp?ArticleID=22305 在ASP.NET中打印表格
该文章转载自德仔工作室:http://www.dezai.cn/Article_Show.asp?ArticleID=20749 CSS实现不同的打印和屏幕显示结果
该文章转载自德仔工作室:http://www.dezai.cn/Article_Show.asp?ArticleID=22006
javascript中几种操作打印的方法
该文章转载自德仔工作室:http://www.dezai.cn/Article_Show.asp?ArticleID=18804
看看这里的演示:http://www.rubylong.cn/doc/print_bill_index.htm