jquery 打印文件流并跳过预览
时间: 2023-07-31 16:05:27 浏览: 27
要实现打印文件流并跳过预览,可以使用以下代码:
```javascript
$.ajax({
url: "path/to/file.pdf",
method: "GET",
xhrFields: {
responseType: 'blob'
},
success: function(data) {
// 创建一个隐藏的 iframe 元素
var iframe = document.createElement('iframe');
iframe.style.display = 'none';
document.body.appendChild(iframe);
// 将文件流转换为 blob 对象,并在 iframe 中打印
var file = new Blob([data], {type: 'application/pdf'});
var fileUrl = URL.createObjectURL(file);
iframe.src = fileUrl;
iframe.contentWindow.print();
}
});
```
这段代码会通过 Ajax 获取 PDF 文件的文件流,将其转换为 Blob 对象,并在隐藏的 iframe 中打印。由于 iframe 是隐藏的,因此不会显示预览。
相关问题
jquery 打印文件流并跳过预览 调用打印机打印
可以使用 JavaScript 的 `window.print()` 方法来调用打印机进行打印。不过,如果要直接打印文件流并跳过预览,需要使用一些特定的技术。
以下是通过 jQuery 实现此目标的代码示例:
```javascript
// 获取文件流
var fileStream = "path/to/file.pdf";
// 通过 AJAX 请求获取文件二进制数据
$.ajax({
url: fileStream,
method: "GET",
xhrFields: {
responseType: "blob"
},
success: function(data) {
// 创建 URL 对象
var fileUrl = URL.createObjectURL(data);
// 创建隐藏的 iframe 元素
var $iframe = $("<iframe/>");
// 隐藏 iframe
$iframe.css("display", "none");
// 添加 iframe 到 DOM 中
$("body").append($iframe);
// 将 iframe 的 src 属性设置为文件 URL
$iframe.attr("src", fileUrl);
// 等待一段时间后,调用 window.print() 方法
setTimeout(function() {
$iframe.get(0).contentWindow.print();
}, 1000);
}
});
```
在上面的代码中,我们首先通过 AJAX 请求获取文件二进制数据,并将其转换为 URL 对象。然后,我们创建一个隐藏的 iframe 元素,并将其 src 属性设置为文件 URL。最后,我们等待一段时间后调用 `window.print()` 方法来触发打印操作。
需要注意的是,由于浏览器的安全限制,我们无法直接打印文件流,必须将其转换为 URL 对象。此外,由于打印操作需要时间,我们需要等待一段时间后再调用 `window.print()` 方法。
jquery 使用iframe 打印文件流 并跳过预览
可以使用 jQuery 创建一个隐藏的 iframe,将文件流作为 iframe 的 src 属性值,这样浏览器就会自动下载并打印文件,同时也跳过了预览的过程。
具体实现步骤如下:
1. 创建一个隐藏的 iframe。
```javascript
var $iframe = $('<iframe>', {
id: 'print-frame',
name: 'print-frame',
style: 'display:none;'
}).appendTo('body');
```
2. 将文件流作为 iframe 的 src 属性值,并设置响应的 HTTP 头信息。
```javascript
$.ajax({
url: '/print',
type: 'POST',
data: fileStream,
processData: false,
contentType: false,
xhrFields: {
responseType: 'blob'
},
success: function(response) {
var blobUrl = URL.createObjectURL(response);
$iframe.attr('src', blobUrl);
$iframe.load(function() {
URL.revokeObjectURL(blobUrl);
$iframe.remove();
});
}
});
```
注意:以上代码仅供参考,具体实现需要根据实际情况进行调整。另外,需要注意打印功能的兼容性问题。不同浏览器可能有不同的实现方式,需要进行测试和兼容处理。
阅读全文