JqGrid web打印实现代码


Posted in Javascript onMay 31, 2011

在IE9中打印没有问题,但IE6、7、8都会出现前几页空白的情况(只显示列头信息),找了很久,才发现是ui-jqgrid-bdiv样式类(在ui.jqgrid.css内)中的overflow引起的,在打印之前将其删除,打印之后将其恢复即可。
打印时的CSS样式如下:

<style type="text/css" media="print"> 
#accordion h3, #vcol, div.loading, div.ui-tabs-hide,ul.ui-tabs-nav li, td.HeaderRight { display:none } 
.ui-jqgrid-titlebar, .ui-jqgrid-title{ display:none } 
.ui-jqgrid-bdiv_self{position: relative; margin: 0em; padding:0; text-align:left;} 
#pager{display:none; z-index:-1;} 
</style>

打印代码:
$("#btnPrint").live("click", function () { 
window.focus(); 
window.print(); 
return false; 
}); 
var GridHeight; 
function window.onbeforeprint() { 
//打印前事件 var jqgridObj=jQuery("#jqgridlist"); 
GridHeight = jqgridObj.jqGrid('getGridParam', 'height');//获取高度 jqgridObj.jqGrid('setGridHeight', '100%');//将其高度设置成100%,主要是为了jqgrid 中有Scroll条时 能把该scroll条内内容都打印出来 $("#gview_jqgridlist .ui-jqgrid-bdiv").removeClass().addClass("ui-jqgrid-bdiv_self");//去除掉overflow属性} 
function window.onafterprint() {//打印后事件 //放开隐藏的元素 
$("#gview_jqgridlist .ui-jqgrid-bdiv_self").removeClass().addClass("ui-jqgrid-bdiv");//恢复overflow属性,否则会导致jqgrid中scroll条消失 jQuery("#jqgridlist").jqGrid('setGridHeight', GridHeight);//设置成打印前的高度}

CSS 媒体属性介绍:
媒介类型(Media Types)允许你定义以何种媒介来提交文档。文档可以被显示在显示器、纸媒介或者听觉浏览器等等。
媒介类型
某些 CSS 属性仅仅被设计为针对某些媒介。比方说 "voice-family" 属性被设计为针对听觉用户终端。其他的属性可被用于不同的媒介。例如,"font-size" 属性可被用于显示器以及印刷媒介,但是也许会带有不同的值。显示器上面的显示的文档通常会需要比纸媒介文档更大的字号,同时,在显示器上,sans-serif 字体更易阅读,而在纸媒介上,serif 字体更易阅读。
@media规则
@media 规则使你有能力在相同的样式表中,使用不同的样式规则来针对不同的媒介。
下面这个例子中的样式告知浏览器在显示器上显示 14 像素的 Verdana 字体。但是假如页面需要被打印,将使用 10 个像素的 Times 字体。注意:font-weight 被设置为粗体,不论显示器还是纸媒介:
<html> 
<head> 
<style> 
@media screen 
{ 
p.test {font-family:verdana,sans-serif; font-size:14px} 
} 
@media print 
{ 
p.test {font-family:times,serif; font-size:10px} 
} 
@media screen,print 
{ 
p.test {font-weight:bold} 
} 
</style> 
</head> 
<body>....</body> 
</html>

不同的媒介类型
注释:媒介类型名称对大小写不敏感。
媒介类型 描述
all 用于所有的媒介设备。
aural 用于语音和音频合成器。
braille 用于盲人用点字法触觉回馈设备。
embossed 用于分页的盲人用点字法打印机。
handheld 用于小的手持的设备。
print 用于打印机。
projection 用于方案展示,比如幻灯片。
screen 用于电脑显示器。
tty 用于使用固定密度字母栅格的媒介,比如电传打字机和终端。
tv 用于电视机类型的设备。
Javascript 相关文章推荐
js 实现复制到粘贴板的功能代码
May 13 Javascript
js判断IE6/IE7/FF的代码[XMLHttpRequest]
Feb 16 Javascript
JavaScript中最简洁的编码html字符串的方法
Oct 11 Javascript
实例详解JavaScript获取链接参数的方法
Jan 01 Javascript
jQuery获得字体颜色16位码的方法
Feb 20 Javascript
一个炫酷的Bootstrap导航菜单
Dec 28 Javascript
js-FCC算法-No repeats please字符串的全排列(详解)
May 02 Javascript
AngularJS中下拉框的基本用法示例
Oct 11 Javascript
vue单页缓存存在的问题及解决方案(小结)
Sep 25 Javascript
jquery+ajax实现上传图片并显示上传进度功能【附php后台接收】
Jun 06 jQuery
Node.js API详解之 module模块用法实例分析
May 13 Javascript
JavaScript Array.flat()函数用法解析
Sep 02 Javascript
16个最流行的JavaScript框架[推荐]
May 29 #Javascript
js 静态动态成员 and 信息的封装和隐藏
May 29 #Javascript
在JavaScript中监听IME键盘输入事件
May 29 #Javascript
解读JavaScript代码 var ie = !-[1,] 最短的IE判定代码
May 28 #Javascript
Jquery css函数用法(判断标签是否拥有某属性)
May 28 #Javascript
最新28个很棒的jQuery 教程
May 28 #Javascript
JavaScript使用IEEE 标准进行二进制浮点运算产生莫名错误的解决方法
May 28 #Javascript
You might like
php中实现可以返回多个值的函数实例
2015/03/21 PHP
PHP7正式版测试,性能惊艳!
2015/12/08 PHP
PHP设计模式之简单投诉页面实例
2016/02/24 PHP
PHP实现统计在线人数功能示例
2016/10/15 PHP
php pdo连接数据库操作示例
2019/11/18 PHP
Mootools 1.2教程 Fx.Morph、Fx选项和Fx事件
2009/09/15 Javascript
window.onload和$(function(){})的区别介绍
2013/10/30 Javascript
Extjs4中Form的使用之本地hiddenfield
2013/11/26 Javascript
JavaScript控制各种浏览器全屏模式的方法、属性和事件介绍
2014/04/03 Javascript
jQuery的图片滑块焦点图插件整理推荐
2014/12/07 Javascript
利用原生JS与jQuery实现数字线性变化的动画
2017/02/24 Javascript
bootstrap suggest搜索建议插件使用详解
2017/03/25 Javascript
BootStrap点击保存后实现模态框自动关闭的思路(模态框)
2017/09/26 Javascript
Three.js基础学习教程
2017/11/16 Javascript
浅谈React Event实现原理
2018/09/20 Javascript
vue实现后台管理权限系统及顶栏三级菜单显示功能
2019/06/19 Javascript
Element Dropdown下拉菜单的使用方法
2020/07/26 Javascript
基于vue-simple-uploader封装文件分片上传、秒传及断点续传的全局上传插件功能
2021/02/23 Vue.js
[46:48]DOTA2上海特级锦标赛A组小组赛#2 Secret VS CDEC第三局
2016/02/25 DOTA
[00:36]DOTA2上海特级锦标赛 LGD战队宣传片
2016/03/04 DOTA
urllib2自定义opener详解
2014/02/07 Python
python中os操作文件及文件路径实例汇总
2015/01/15 Python
Numpy数据类型转换astype,dtype的方法
2018/06/09 Python
python 一个figure上显示多个图像的实例
2019/07/08 Python
pytorch加载自己的图像数据集实例
2020/07/07 Python
Raleigh兰令自行车美国官网:英国凤头牌自行车
2018/01/08 全球购物
伊莱克斯阿根廷网上商店:Tienda Electrolux
2021/03/08 全球购物
美国价格实惠的在线眼镜网站:Zeelool
2020/12/25 全球购物
专科文秘应届生求职信
2013/11/18 职场文书
会计学个人自荐信模板
2013/12/13 职场文书
函授毕业生自我鉴定范文
2014/03/25 职场文书
升旗仪式演讲稿
2014/05/08 职场文书
安全演讲稿大全
2014/05/09 职场文书
禁毒宣传标语
2014/06/19 职场文书
归途列车观后感
2015/06/17 职场文书
HTML基础详解(下)
2021/10/16 HTML / CSS