VUE调用打印机打印页面(VUE3版)

之前有个VUE2版的实现方法:

VUE调用打印机打印页面_vue调用一体式打印机-CSDN博客

因为项目需要,现在要搞一个VUE3版的

大致的需求是:通过点击一个按钮,弹出一个对话框,然后对话框上有个打印按钮,点了后,会把需要打印的内容通过调用本地的打印机打印出来。

(吐槽一下那个AI啊,折腾了两个小时,一直离成功差那么一点点,让我装这个插件那个插件的。后来只能自己现学现用把代码改出来了。所以说人工智能顶替程序员的事不太靠谱。)

实现的方法:

1.先做一个print.js

javascript 复制代码
export default {
    mounted(el, binding) {
        const content = binding.value;
        console.log(`打印内容: ${content}`);
        // 执行实际的打印逻辑
    }
};

2.在man.js里注册一下

javascript 复制代码
import printDirective from './directives/print'; // 确保路径正确

app.directive('print', printDirective);

3.在页面里调用

html的部分

html 复制代码
    <div id="app1">
      <el-dialog v-model="dialogVisible" title="对话框" ref="dialogRef">
        <div ref="printArea">
          <p>{{ dialogContent }}</p>
          <img :src="profileImageUrl" alt="Profile Image" @load="onImageLoad" />
          <p>测试用的文字</p>
          <table>
            <tr>
              <td>1</td>
              <td>2</td>
            </tr>
          </table>
        </div>
        <template #footer>
        <span class="dialog-footer">
          <el-button @click="dialogVisible = false">取消</el-button>
          <el-button type="primary" @click="printDialogContent">打印</el-button>
        </span>
        </template>
      </el-dialog>
      <el-button @click="showDialog">显示对话框</el-button>
    </div>

js的部分

javascript 复制代码
// 对话框状态
const dialogVisible = ref(false);

// 对话框内容
const dialogContent = ref('这是要打印的内容');

// 图片路径
const profileImageUrl = 'https://via.placeholder.com/150';

// 对话框引用
const dialogRef = ref(null);

// 打印区域引用
const printArea = ref(null);

// 图片是否已加载完成
const imageLoaded = ref(false);

// 显示对话框
const showDialog = () => {
  dialogVisible.value = true;
};

// 图片加载完成事件
const onImageLoad = () => {
  imageLoaded.value = true;
};

// 打印对话框内容
const printDialogContent = () => {
  if (dialogVisible.value && dialogRef.value && printArea.value) {
    const printElement = printArea.value;

    if (!imageLoaded.value) {
      console.warn('图片尚未加载完成,请稍后重试。');
      return;
    }

    const createPrintWindow = () => {
      const newWindow = window.open('', '_blank'); // 创建一个新的空白窗口
      if (newWindow) {
        setTimeout(() => {
          newWindow.document.write('<html><head><title>打印内容</title></head><body>');
          newWindow.document.write(printElement.innerHTML);
          newWindow.document.write('</body></html>');
          newWindow.document.close();

          // 触发打印
          newWindow.print();

          // 关闭窗口
          newWindow.close();
        }, 100); // 延迟100毫秒执行
      } else {
        console.error('无法打开新窗口');
      }
    };

    createPrintWindow();
  }
};

这里有个坑,因为主动打开窗口会被EDGE拦截,所以就延迟了100ms,如果用谷歌浏览器打开,就完全没这个问题。

相关推荐
-凌凌漆-18 分钟前
【vue】选项式api与组合式api
前端·javascript·vue.js
2601_9498095920 分钟前
flutter_for_openharmony家庭相册app实战+通知设置实现
android·javascript·flutter
可触的未来,发芽的智生43 分钟前
发现:认知的普适节律 发现思维的8次迭代量子
javascript·python·神经网络·程序人生·自然语言处理
BYSJMG1 小时前
计算机毕业设计选题推荐:基于大数据的肥胖风险分析与可视化系统详解
大数据·vue.js·数据挖掘·数据分析·课程设计
0思必得02 小时前
[Web自动化] Selenium处理文件上传和下载
前端·爬虫·python·selenium·自动化·web自动化
phltxy3 小时前
Vue3入门指南:从环境搭建到数据响应式,开启高效前端开发之旅
前端·javascript·vue.js
小飞大王6663 小时前
CSS基础知识
前端·css
Charlie_lll3 小时前
学习Three.js–风车星系
前端·three.js
代码游侠3 小时前
学习笔记——Linux内核与嵌入式开发1
linux·运维·前端·arm开发·单片机·嵌入式硬件·学习
玩电脑的辣条哥3 小时前
幽灵回复AI已回复但前端不显示的排查与修复
前端·人工智能