使用jquery+CSS实现控制打印样式


Posted in Javascript onDecember 31, 2014

一、添加打印样式

1. 为屏幕显示和打印分别准备一个css文件,如下所示:
  用于屏幕显示的css: <link rel="stylesheet" href="css/mainstylesheet.css" media="screen" />
  用于打印的css:<link rel="stylesheet" href="css/printstylesheet.css" media="print" />

2. import方式:
  <style type="text/css">
      @import url("css/printstylesheet.css") print;
  </style>

3. 直接把屏幕显示样式和打印样式写在一个css文件中:
  @media print {}{
    h1 {
      color: black;
    }
    h2 {}{
      color: gray;
    }
  }
  @media print里面的内容只对打印出来的内容有效,之外的内容就是屏幕显示的样式。

其他:
创建一个不指定媒体类型的样式表通常很有用(或者利用media="all")。当你准备好定义一些特别用
于打印的规则时,可以只创建一个单独的样式表,使任何在打印时看起来不好的样式都失效。使用这种方法的一个问题是必须确保打印机样式实际上确实覆盖了主样式表。可以使用!important.

二、打印样式注意事项:

1. 打印样式中不推荐使用背景,因为浏览器默认情况下并不能打印出CSS中的背景内容,只有当浏览器被
  设置可以打印背景的情况下才能打印出背(ie的高级选项中可选)。即使背景可以打印,它也可能盖过叠在它上面的任何文本。
  这是真的,尤其对于用彩色背景在显示器上强烈对比的文本,但是在黑白打印机上打印时会融合这一背景。
  background:none;去掉背景
  图片和颜色。

  可以利用background-color属性设置背景颜色为白色,像这样: font-family: Arial; line-height: 26px;">  使用background的快捷法也可以获得相同的效果:background: white。因此像background: white;
  这样的声明不仅设置了背景颜色为白色,而且消除了所有背景图片。利用这个background的快捷属性,
  你实现了两个目的——设置了一个白色背景,并消除了图片——只用很少的代码。
 
2. 如果需要在打印内容中出现图片,请在HTML代码中加入。

3. 打印设置使用的是物理单位,所以尺寸最好不要用像素(px),可以用pt也可以用cm;

4. 隐藏不需要的或是次要的内容。display:none;

5. 尽量不要让内容浮动,有些浏览器打印浮动的div的过程中,会有一个麻烦,需要特别加以注意。
 不要在打印的样式表中浮动的块,像这样:float: none;。例如,基于Gecko的浏览器
 (例如Netscape 6+),当用户用它来浏览一个打印输出页面时,它会截去浮动元素中的内容。
 这些内容就不会被传送到打印机,下一个页面也不会有它的踪影??它消失了。

6. 尽可能的在HTML代码中做好内容重要的先后次序,这样在打印样式中可以节省不少的麻烦。

7. 打印与网页不一样,打印一定要留下白边,单位用英寸(in)。

8. 要确保页面上的所有文本以黑色打印,就用通配选择器(见第54页)和!important来创建把每个
  标签都格式化为黑色文本的单个样式:
  *{ color: ##000# !important }

9. 在打印中显示链接url的信息:利用一个高级的选择器:after和一个高级的CSS属性称作content,
  把不在屏幕上显示的文本打印在一个样式元素的末端。
  不幸的是,:after选择器和content属性技巧在Internet Explorer 6或者更早的版本上不起作用
  (到编写本书为止,在IE 7上也不行)。但是它在Firefox和Safari上的确可以,因此你至少可以清楚
  地说明URL以便访问者可以使用他们的浏览器。

  为了做到这点,给打印样式表添加一个样式,在每个链接后面打印出URL。你甚至可以添加其他文本项
  目比如圆括号,使它更好看些:
  a:after {content: " (" attr(href) ") ";}

  然而,这个CSS不区分外部或者内部的链接,因此它也打印出到达同一个网站其他页面的没用的相对
  文档链接:“访问主页(../../index. html)。”利用一点点CSS 3魔法,就可以强制这个样式只打
  印绝对的URL(即以http://开头的那些),像这样:
  a[href^="http://"]:after {content: " (" attr(href) ") ";}

10.给打印添加分页符:两种被广泛认可的属性是page-break-before和page-break-after。
  page-break-before告诉网页浏览器在一个指定样式之前插入一个分页符。利用page-break-before
  属性使图片打印在一张新页面上,并且适合整张页面。
  要使一个元素作为打印页上的最后一个项目显示,就给那个元素的样式添加page-break-after: always。

  创建两个类样式,以类似于.break_after和.break_before的名字来命名,像这样:
  .break_before { page-break-before: always; }
  .break_after { page-break-after: always; }

  然后你可以选择性地把这些样式应用给应该打印在网页顶部或者底部的元素。

三、测试打印样式

通常来说我们不可能用打印机来进行测试,在IE浏览器菜单栏“文件”中有“打印预览”,可以通过这
打印预览来做测试。

Javascript 相关文章推荐
善用事件代理,警惕闭包的性能陷阱。
Jan 20 Javascript
jQuery基本过滤选择器使用介绍
Apr 18 Javascript
学习使用AngularJS文件上传控件
Feb 16 Javascript
js操作DOM--添加、删除节点的简单实例
Jul 08 Javascript
基于百度地图实现产品销售的单位位置查看功能设计与实现
Oct 21 Javascript
vue2.0结合DataTable插件实现表格动态刷新的方法详解
Mar 17 Javascript
JavaScript实现打地鼠小游戏
Apr 23 Javascript
关于vue.extend和vue.component的区别浅析
Aug 16 Javascript
Vue调试神器vue-devtools安装方法
Dec 12 Javascript
JavaScript中arguments和this对象用法分析
Aug 08 Javascript
JavaScript enum枚举类型定义及使用方法
May 15 Javascript
Vue执行方法,方法获取data值,设置data值,方法传值操作
Aug 05 Javascript
浅谈javascript中字符串String与数组Array
Dec 31 #Javascript
jQuery中[attribute!=value]选择器用法实例
Dec 31 #Javascript
JavaScript中的Primitive对象封装介绍
Dec 31 #Javascript
JavaScript中的值类型转换介绍
Dec 31 #Javascript
javascript实现滑动解锁功能
Dec 31 #Javascript
JavaScript中number转换成string介绍
Dec 31 #Javascript
JavaScript中string转换成number介绍
Dec 31 #Javascript
You might like
php实现的一个简单json rpc框架实例
2015/03/30 PHP
ThinkPHP中数据操作案例分析
2015/09/27 PHP
js url传值中文乱码之解决之道
2009/11/20 Javascript
js跑马灯代码(自写)
2013/04/17 Javascript
jquery中get,post和ajax方法的使用小结
2014/02/04 Javascript
详解JavaScript编程中正则表达式的使用
2015/10/25 Javascript
浅谈jquery中ajax跨域提交的时候会有2次请求的问题
2017/11/10 jQuery
原生JS实现动态添加新元素、删除元素方法
2019/05/05 Javascript
微信小程序scroll-view的滚动条设置实现
2020/03/02 Javascript
记一次vue跨域的解决
2020/10/21 Javascript
[05:22]DOTA2 2015国际邀请赛中国区预选赛首日TOP10
2015/05/26 DOTA
[01:03:27]NAVI vs EG 2019国际邀请赛小组赛 BO2 第一场 8.15
2019/08/17 DOTA
用python 制作图片转pdf工具
2015/01/30 Python
python之matplotlib学习绘制动态更新图实例代码
2018/01/23 Python
使用python根据端口号关闭进程的方法
2018/11/06 Python
python 检查文件mime类型的方法
2018/12/08 Python
Python3.7 dataclass使用指南小结
2019/02/22 Python
Python pickle模块实现对象序列化
2019/11/22 Python
Python数据可视化:泊松分布详解
2019/12/07 Python
Django app配置多个数据库代码实例
2019/12/17 Python
Python 支持向量机分类器的实现
2020/01/15 Python
浅谈多卡服务器下隐藏部分 GPU 和 TensorFlow 的显存使用设置
2020/06/30 Python
Django启动时找不到mysqlclient问题解决方案
2020/11/11 Python
html5跨域通讯之postMessage的用法总结
2013/11/07 HTML / CSS
英国女性时尚精品店:THE DRESSING ROOM
2018/05/23 全球购物
俄罗斯有趣和原创礼物网上商店:MagicMag
2019/08/01 全球购物
体育教育专业毕业生自荐信
2013/11/15 职场文书
银行实习的自我鉴定
2013/12/10 职场文书
采购部经理岗位职责
2014/02/10 职场文书
竞选学生会主席演讲稿
2014/04/24 职场文书
森林病虫害防治方案
2014/06/02 职场文书
员工工作能力评语
2014/12/31 职场文书
运动会表扬稿范文
2015/05/05 职场文书
2016年全国爱牙日宣传活动总结
2016/04/05 职场文书
Oracle 区块链表创建过程详解
2021/05/15 Oracle
微信小程序中使用vant框架的具体步骤
2022/02/18 Javascript