Js 实现局部打印功能
1.当前页面
var bodyHtml = window.document.body.innerHTML;
window.document.body.innerHTML = printHtml;//printHtml为当前需要打印的div的内容
window.print();
window.document.body.innerHTML = bodyHtml;
缺点: (1)移除页面内容再插入需要打印页面内容,页面会有一个大的跳动
(2)页面事件效果会丢失
2.iframe 打印
function myPrint(){
var el = "<div>Content should be print!</div>";
var iframe = document.createElement('IFRAME');
iframe.setAttribute('style', 'position:absolute;width:0px;height:0px;left:-500px;top:-500px;');
document.body.appendChild(iframe);
var doc = iframe.contentWindow.document;
doc.write(el);
var pageStyle="html,body{height:100%}img{max-width:100%;max-height:100%;margin:0 auto}";
var style=document.createElement("style");
style.innerText= pageStyle;
doc.getElementsByTagName("head")[0].appendChild(style)
doc.close();
iframe.contentWindow.focus();
iframe.contentWindow.print();
)
缺点: 需要将所有style拷贝到iframe
3.media query 实现
@media print {
.no-need-print-block
{
display: none;
}
}
缺点: 一块多个地方复用的模块不好customize
4.reactComponent:
import React, { PureComponent } from 'react';
import { string } from 'prop-types';
export default class Print extends PureComponent {
static propTypes = {
printHtml: string,
};
static defaultProps = {
printHtml: 'test html',
}
setPageStyles = (iDom) => {
const styles = document.getElementsByTagName('style');
const IHead = iDom.getElementsByTagName('head')[0];
let pageStyle = '';
Array.from(styles).map((s) => {
pageStyle += s.innerHTML;
});
const style = document.createElement('style');
style.innerHTML = pageStyle;
IHead.appendChild(style);
}
handlePrint = () => {
const { printHtml } = this.props;
const iFrame = this.iframe;
const iFrameWindow = iFrame.contentWindow;
const iDom = iFrameWindow.document;
iDom.write(printHtml);
this.setPageStyles(iDom);
iDom.close();
iFrameWindow.print();
}
render() {
return (
<div>
<button style={{ backgroundColor: 'yellow', cursor: 'pointer' }} onClick={this.handlePrint}>print button</button>
<iframe title="print iframe" style={{ position: 'absolute', width: '0', height: '0', left: '-500px', top: '-500px' }} ref={(iframe) => { this.iframe = iframe; }}/>
</div>
);
}
}
缺点: 需要将所有style拷贝到iframe
打印方法兼容性解决方法:
if (document.queryCommandSupported('print')) {
document.execCommand('print', false, null);
} else {
window.print();
}
firefox 只打印一页问题解决: firefox 打印display: flex; display: inline-block; 改display:block;去掉float:left/right;
在desktop显示正常,但是在移动端显示变为小圆圈,无法正确展示选中取消选中效果问题解决方案:
display: block;
width: 58px;
height: 20px;
-webkit-appearance: checkbox;
-moz-appearance: checkbox;
Js 实现局部打印功能的更多相关文章
- js调用局部打印功能并还原
function printme() { //printMain为要打印的dom元素 window.document.body.innerHTML = document.getElementById( ...
- js实现地图打印功能
注意:js对地图的打印功能在arcgis10.1中才有提供,所以如果要使用esri自带的地图打印功能,必须使用arcgis 10.1或更高版本的地图打印模板.(由于官网和arcgis desktop提 ...
- js实现浏览器打印功能
最近接触到一个新需求,实现打印机打印小票的功能.打的一桌子小票(惭愧),不过也基本满足了业务上的需求,现在分享一下如何实现(好记性不如烂笔头) 先上代码 // 布局代码 <div id=&quo ...
- js插件添加打印功能
<%@ page language="java" %> <%@ page contentType="text/html; charset=gb2312& ...
- 使用jquery.jqprint.js 实现的打印功能,IE9不能进行打印预览、火狐打印空白界面
提示的内容:SCRIPT438: 对象不支持“ExecWB”属性或方法 首先解决IE9不能打印预览的问题: 查找了一大推资料 ,有两种说法:一种是IE的安全性级别太高:一种是需要安装什么 微软we ...
- js 前端实现打印功能
// 此处是一个打印的方法 可以在点击事件的时候调用 dayin = () =>{ // 获取当前页面要打印的内容 // 这里的className(‘print’)是我给要打印的区域起的 ...
- 转载js实现打印功能
<div id="print">打印的内容</div><a href="javascript:void(0)" onclick=& ...
- 前端打印功能实现及css设置
首先是使用下边代码,实现js局部打印功能.参数dom为需要打印的节点,为了保证页面功能的单一性,最好弹出一个新的预览页面完成打印功能. function print(dom){ var body = ...
- 网站开发进阶(十二)JS实现打印功能(包括打印预览、打印设置等)
JS实现打印功能(包括打印预览.打印设置等) 绪 最近在进行项目开发时,需要实现后台管理端打印功能,遂在网上一阵搜索,搜到了很多相关的文章.其中绝大部分文章都是使用的Lodop5.0(Web打印和套打 ...
随机推荐
- Springboot与ActiveMQ、Solr、Redis中分布式事物的初步探索
Springboot与ActiveMQ.Solr.Redis中分布式事物的初步探索 解决的场景:事物中的异步问题,当要求数据库与solr服务器的最终一致时. 程序条件: 利用消息队列,当数据库添加成功 ...
- MySql 数据库 SQLException: The user specified as a definer ('root'@'%') does not exist 错误原因及解决办法
The user specified as a definer ('root'@'%') does not exist 此种报错主要是针对访问视图文件引起的(没有权限) 经查明:是用户root并没有获 ...
- centos安装nodejs和配置npm
1.下载安装nodejs 1 wget http://nodejs.org/dist/v7.4.0/node-v7.4.0.tar.gz 2 yum install gcc openssl-devel ...
- appium+python+iOS 环境搭建,安装fbsimctl
(1)设置postBuffer的值 开始如下的安装之前,需先修改postBuffer的值,默认的比较下,会导致下载大文件时失败, 参考链接:http://blog.sina.com.cn/s/blog ...
- stm32 HardFault_Handler调试及问题查找方法
STM32出现HardFault_Handler故障的原因主要有两个方面: 1.内存溢出或者访问越界.这个需要自己写程序的时候规范代码,遇到了需要慢慢排查. 2.堆栈溢出.增加堆栈的大小. 出现问题时 ...
- JavaScript是如何工作的01:引擎,运行时和调用堆栈的概述!
概述 几乎每个人都已经听说过 V8 引擎,大多数人都知道 JavaScript 是单线程的,或者它使用的是回调队列. 在本文中,我们将详细介绍这些概念,并解释 JavaScrip 实际如何运行.通过了 ...
- Greenplum 调优--数据分布法则 - 分布列与分区的选择
分布列选择黄金法则 由于Greenplum是一个分布式的数据库,数据是分散存储在各个数据节点的,所以需要告诉Greenplum数据应该如何分布. 短板效应 当用户请求QUERY时,Greenplum会 ...
- 带着历史提交记录迁移git仓库
1. git push --mirror --mirror模式会把本地的分支都克隆 // 先用--bare克隆裸仓库 git clone git@gitee.com:zhangamie/testApp ...
- hdu6468(记忆化搜索)
zyb的面试 Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/65536 K (Java/Others)Total Subm ...
- js 返回两数(包含这两数)之间的随机数函数
function selectFrom( lowerValue, upperValue ){ var choices = upperValue - lowerValue + 1; return Mat ...