js打印页面图片(批量)

本文介绍了一种使用JavaScript批量打印页面中图片的方法。通过创建IFRAME并在其中加载包含多个图片的HTML内容,然后利用onload事件处理函数确保所有图片加载完毕后调用打印功能。这种方法适用于需要一次性打印多张相同图片的场景。
摘要由CSDN通过智能技术生成

js打印页面图片(批量)

html代码:

<body>
	<button onclick="printThisWindow()">打开</button>
</body>

js代码

let list = `<div class="imgBox">`
			for (var i = 0; i < 10; i++) {
				//防止批量打印时打印界面重复调用
				if(i == 0){
					list += `<img src="https://scpic.chinaz.net/files/pic/pic9/202110/hpic4550.jpg" style="width: 842px;height: 600px;" onload="___imageLoad___()"/>`;
				}else{
					list += `<img src="https://scpic.chinaz.net/files/pic/pic9/202110/hpic4550.jpg" style="width: 842px;height: 600px;"/>`;
				}
				
			}
		list += `</div>`
	
	

	function printThisWindow() {
	    let iframe = document.createElement('IFRAME')
	    let doc = null
	    iframe.setAttribute('class', 'print-iframe')
	    iframe.setAttribute('style', 'position:absolute;width:0px;height:0px;left:-500px;top:-500px;')
	    document.body.appendChild(iframe)
	    doc = iframe.contentWindow.document
	    // 取一个不重复的方法名称,可以随机字符串
	    doc.___imageLoad___ = function () {
	        iframe.contentWindow.print()
	        if (navigator.userAgent.indexOf('MSIE') > 0) {
	            document.body.removeChild(iframe)
	        }
	    }
	    doc.write(`${list}`)
	    doc.close()
	    iframe.contentWindow.focus()
	}
要通过JavaScript设置打印机并批量打印网络图片,你需要分几步操作: 1. **打印机设置**[^1]: - 针对特定的热敏打印机,可能需要了解其驱动程序提供的API(如Zebra打印机)或者使用浏览器的打印机选择功能。确保打印机已连接到电脑,并且在网页上设置时可被浏览器识别。 2. **JS实现打印功能**: - 使用`window.print()`函数时,通常需要确保图片已经加载完成,因为这个函数会在调用时立即开始打印。可以先创建一个 `<img>` 标签,设置src属性为网络图片地址,当图片加载完成后触发打印。 ```javascript const imgElement = document.createElement('img'); imgElement.src = 'your_image_url'; imgElement.onload = function() { window.print(imgElement); }; document.body.appendChild(imgElement); // 添加到页面以便于检测加载 ``` 3. **批量打印**[^2]: - 如果需要批量打印多张图片,可以在一个循环中创建多个`<img>`元素,每个元素对应一张图片,然后依次触发打印。 ```javascript const urls = ['image_url_1', 'image_url_2', 'image_url_3']; urls.forEach(url => { const imgElement = document.createElement('img'); imgElement.src = url; imgElement.onload = function() { window.print(imgElement); }; document.body.appendChild(imgElement); }); ``` 4. **注意点**: - 可能会遇到兼容性问题,不同浏览器对于`window.print()`的支持程度不一。 - 对于某些场景,可能需要考虑用户的确认提示,防止未经用户同意就打印
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

qq_42208679

生命不息,写作不止,求打赏!

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值