当前位置:首页 > VUE

vue实现打印功能

2026-02-18 09:00:13VUE

使用vue-print-nb插件实现打印

安装vue-print-nb插件

npm install vue-print-nb --save

在main.js中引入并注册插件

import Print from 'vue-print-nb'
Vue.use(Print)

在组件中使用v-print指令

<template>
  <button v-print="printObj">打印</button>
  <div id="printContent">
    <!-- 需要打印的内容 -->
  </div>
</template>

<script>
export default {
  data() {
    return {
      printObj: {
        id: 'printContent',
        popTitle: '打印标题' // 打印窗口的标题
      }
    }
  }
}
</script>

使用window.print()原生方法实现

创建打印方法

methods: {
  handlePrint() {
    const printContent = document.getElementById('printContent').innerHTML
    const originalContent = document.body.innerHTML

    document.body.innerHTML = printContent
    window.print()
    document.body.innerHTML = originalContent
  }
}

在模板中添加打印按钮和内容区域

<button @click="handlePrint">打印</button>
<div id="printContent">
  <!-- 需要打印的内容 -->
</div>

使用CSS控制打印样式

添加打印专用样式表

<link rel="stylesheet" href="print.css" media="print">

或在现有样式表中添加媒体查询

@media print {
  body * {
    visibility: hidden;
  }
  #printContent, #printContent * {
    visibility: visible;
  }
  #printContent {
    position: absolute;
    left: 0;
    top: 0;
  }
}

处理打印分页问题

通过CSS控制分页

@media print {
  .page-break {
    page-break-after: always;
  }
}

在需要分页的位置添加分页元素

vue实现打印功能

<div class="page-break"></div>

注意事项

打印前确保内容已完全加载,特别是异步数据 动态内容打印时需要注意恢复原始DOM状态 复杂的表格和布局可能需要特殊CSS处理 某些浏览器可能需要用户手动启用弹出窗口

标签: 功能vue
分享给朋友:

相关文章

vue实现录音文件播放

vue实现录音文件播放

使用 Vue 实现录音文件播放 准备工作 确保项目中已安装必要的依赖,如 vue-audio-recorder 或原生 Web Audio API。录音文件播放通常涉及录音、存储和播放三个核心环节。…

vue实现答题

vue实现答题

Vue 实现答题功能 数据结构设计 使用 Vue 的响应式特性管理题目和答案数据。通常需要以下数据结构: data() { return { questions: [ {…

vue 实现平面

vue 实现平面

Vue 实现平面的方法 在 Vue 中实现平面效果通常涉及 CSS 样式、UI 框架或自定义组件的使用。以下是几种常见方法: 使用 CSS 样式 通过 Vue 的样式绑定或 scoped CSS 为…

vue实现气泡

vue实现气泡

Vue 实现气泡效果的方法 在 Vue 中实现气泡效果可以通过 CSS 动画、第三方库或自定义组件完成。以下是几种常见实现方式: 使用纯 CSS 和 Vue 过渡 通过 Vue 的过渡系统结合 CS…

vue sku 实现

vue sku 实现

Vue SKU 实现方案 在电商系统中,SKU(Stock Keeping Unit)是商品的最小库存单位,通常由多个属性组合而成(如颜色、尺寸等)。以下是基于 Vue 的实现方案。 数据结构设计…

vue实现权限

vue实现权限

Vue 实现权限管理的方法 在 Vue 项目中实现权限管理通常涉及路由控制、按钮权限和接口权限。以下是几种常见的实现方式: 路由权限控制 通过动态路由的方式,根据用户权限加载不同的路由配置。可以使用…