【发布时间】:2013-01-12 09:11:49
【问题描述】:
我正在创建一个自定义 GridView 数据打印窗口,该窗口旨在打印出 gridview 区域。一个按钮将打印当前窗口的网格视图,另一个按钮将打印 GridView 中的所有记录。就目前的代码而言,当单击按钮时(分别打印当前页面和所有记录),预览窗口完美地显示了 GridView 中的所有记录(23 列,包括 GridView 两侧的两个命令字段)。但是,当打印出作业时,无论我调整什么打印机或 CSS/格式设置,网格视图都会被切掉(只显示大约一半的网格)。
我遇到的两个挑战是 1)我无法以纵向或横向打印完整的 gridview 以及 2)我的 javascript 很弱。如何调整以下代码,以便在打印 gridview 时打印 FULL 网格?
如果需要更多信息,请随时询问。
这是我的 aspx 文件后面的打印按钮代码。
protected void PrintCurrentPage_Click(object sender, EventArgs e)
{
GridView1.PagerSettings.Visible = false;
GridView1.DataBind();
StringWriter sw = new StringWriter();
HtmlTextWriter hw = new HtmlTextWriter(sw);
GridView1.RenderControl(hw);
string gridHTML = sw.ToString().Replace("\"", "'")
.Replace(System.Environment.NewLine, "");
StringBuilder sb = new StringBuilder();
sb.Append("<script type = 'text/javascript'>");
sb.Append("window.onload = new function(){");
sb.Append("var printWin = window.open('', '', 'left=0");
sb.Append(",top=0,width=3000,height=600,status=0');");
sb.Append("printWin.document.write(\"");
sb.Append(gridHTML);
sb.Append("\");");
sb.Append("printWin.document.close();");
sb.Append("printWin.focus();");
sb.Append("printWin.print();");
sb.Append("printWin.close();};");
sb.Append("</script>");
ClientScript.RegisterStartupScript(this.GetType(), "GridPrint", sb.ToString());
GridView1.PagerSettings.Visible = true;
GridView1.DataBind();
}
这是打印所有记录的代码。
protected void PrintAll_Click(object sender, EventArgs e)
{
GridView1.AllowPaging = false;
GridView1.DataBind();
StringWriter sw = new StringWriter();
HtmlTextWriter hw = new HtmlTextWriter(sw);
GridView1.RenderControl(hw);
string gridHTML = sw.ToString().Replace("\"", "'")
.Replace(System.Environment.NewLine, "");
StringBuilder sb = new StringBuilder();
sb.Append("<script type = 'text/javascript'>");
sb.Append("window.onload = new function(){");
sb.Append("var printWin = window.open('', '', 'left=0");
sb.Append(",top=0,width=3000,height=600,status=0');");
sb.Append("printWin.document.write(\"");
sb.Append(gridHTML);
sb.Append("\");");
sb.Append("printWin.document.close();");
sb.Append("printWin.focus();");
sb.Append("printWin.print();");
sb.Append("printWin.close();};");
sb.Append("</script>");
ClientScript.RegisterStartupScript(this.GetType(), "GridPrint", sb.ToString());
GridView1.AllowPaging = true;
GridView1.DataBind();
}
【问题讨论】:
-
你的意思是在两种情况下“printall”和“printCurrentPage”你只打印当前页面吗?
-
抱歉,在这两种情况下,当单击按钮时,都会出现一个格式化的打印预览窗口(所有其他网页装饰都被剥离),该窗口仅显示完整的 GridView 区域,紧接着是操作系统“打印”窗口询问我想用什么打印机连同打印机选项一起打印。单击操作系统打印窗口中的“打印”按钮时,仅打印出一半的打印区域。
-
我应该注意到总共有 23 列,包括 GridView 两侧的两个命令字段。
-
在这种情况下我们通常做的实际上是有两个
<table>,我们只使用 CSS 规则从显示中隐藏并在打印时显示...这也将更容易维护,并且无需弹出窗口(它们对用户来说非常烦人) -
@balexandre - 今天早些时候我一直在玩 CSS 选项,但无法让任何东西正常工作。也许,我没有调整正确的设置。你能提供一个你所指的样本吗?
标签: c# javascript asp.net css gridview