Vue打印预览功能实现:利用vue-print-nb插件

更新日期: 2025-07-12阅读: 27标签: 插件

在Web项目中,用户经常需要打印页面内容。直接使用浏览器的打印功能(Ctrl+P)往往效果不理想:布局错乱、样式丢失、多余元素被打印出来。vue项目中插件可以轻松解决这些问题,实现专业的打印预览功能。


第一步:安装vue-print-nb插件

这个插件能帮助我们快速添加打印功能:

npm install vue-print-nb --save
# 或
yarn add vue-print-nb


第二步:在Vue项目中配置插件

在main.js中全局引入:

import Print from 'vue-print-nb'

Vue.use(Print)


第三步:创建打印区域模板

<template>
  <div>
    <!-- 打印按钮 -->
    <button v-print="printConfig">打印当前内容</button>
    
    <!-- 隐藏非打印内容 -->
    <div class="non-printable">
      这部分不会被打印
    </div>
    
    <!-- 打印区域 -->
    <div id="printArea">
      <h2>销售订单</h2>
      <table>
        <tr>
          <th>产品名称</th>
          <th>数量</th>
          <th>单价</th>
        </tr>
        <tr>
          <td>Vue教程</td>
          <td>1</td>
          <td>¥99</td>
        </tr>
      </table>
    </div>
  </div>
</template>

<script>
export default {
  data() {
    return {
      printConfig: {
        id: "printArea",     // 要打印的区域ID
        popTitle: '订单详情', // 打印窗口标题
        extracss: 'https://example.com/print-styles.css', // 额外CSS
        extraHead: '<meta http-equiv="Content-Language" content="zh-cn"/>'
      }
    }
  }
}
</script>

<style>
/* 普通屏幕样式 */
.non-printable {
  background: #f0f0f0;
  padding: 10px;
}

/* 专门用于打印的样式 */
@media print {
  body * {
    visibility: hidden; /* 隐藏所有元素 */
  }
  
  #printArea,
  #printArea * {
    visibility: visible; /* 只显示打印区域 */
  }
  
  #printArea {
    position: absolute;
    left: 0;
    top: 0;
    width: 100%;
  }
  
  .no-print {
    display: none !important; /* 强制隐藏不需要的元素 */
  }
}
</style>


第四步:关键配置说明

  1. 指定打印区域:通过id绑定要打印的dom元素

  2. 自定义打印标题:popTitle设置打印窗口的标题

  3. 添加打印专用样式:使用@media print媒体查询

  4. 隐藏不需要的元素:给元素添加no-print类


常见问题解决

  • 页眉页脚显示问题:在打印设置中取消页眉页脚

  • 背景颜色不打印:在浏览器设置中勾选"背景图形"

  • 分页问题:在CSS中使用page-break-before: always;控制分页

  • 移动端适配:确保打印区域宽度设置为100%


优化打印体验的技巧

  1. 简化打印内容:移除不必要的图片和广告

  2. 使用PDF替代:通过window.print()转为PDF更灵活

  3. 固定尺寸:使用cm或mm单位确保打印尺寸准确

  4. 测试不同浏览器:Chrome/Firefox的打印表现可能不同

实现Vue打印预览功能后,用户点击打印按钮时,只会输出指定区域的内容,保持页面原有布局不变。这种方法比直接使用浏览器打印更专业,能确保表格、图表等复杂内容的打印效果。

通过合理的CSS打印媒体查询控制,可以进一步优化打印页面的边距、字体大小和分页效果。这种Vue打印解决方案适用于订单、报表、合同等需要精确打印的场景,大幅提升用户体验。

链接: https://fly63.com/article/detial/12856

对于前端开发,整理推荐好用的chrome插件或应用

向web前端开发者整理提供的chrome插件或应用:比如Postman、JSON Viewer、Page Ruler 、ChromeADB 等等

使用原生js开发插件的实现方法

作为前端开发,我们都习惯使用一些开源的插件例如jquery工具库,那么如何使用原生js来开发封装一个自己的插件呢?接下来就看一下怎么去开发一个自己的js插件,先上代码

typeahead.js_jquery input 搜索自动补全jQuery插件

jquery.typeahead.js是一款高级的自动补全jQuery插件。该自动补全插件提供超过50个配置选项和回调方法,用于完成自动补全功能,能够完成绝大部分表单自动补全的需求。

js轮播插件_轮播图js代码插件总汇

这篇文章为大家分享图片轮播插件,最全最简单最通用的 幻灯片轮播插件,pc端和移动端都可完美使用,能满足绝大部分网站的轮播需求。js轮播插件包括Swiper、slick、owl carousel2、jssor/slider 、iSlider 等

ios风格的时间选择插件

在上个项目中,客户希望时间选择插件可以是ios风格的那种,但是找了很久,发现并没有用vue的ios风格时间插件,于是自己便自己造了一个轮子.插件依赖于better-scroll和vue

前端最常用的vscode插件集

在前端开发中,使用Visual Studio Code有哪些你常用的插件?推荐几个自己喜欢的,不带链接,自己搜索安装吧。这些都是比较实用、前端必备的插件集

浏览器插件_常用谷歌浏览器插件推荐

常用谷谷歌浏览器确实没有其它国产软件的内置功能丰富。但是 Google 浏览器的的优点恰恰就体现在拥有超简约的界面,以及支持众多强大好用的扩展程序,用户能够按照自己的喜好去个性化定制浏览器。今天我就给大家介绍几款自己常用的插件。

sublime安装插件

安装Sublime text 2插件很方便,可以直接下载安装包解压缩到Packages目录,也可以安装package control组件,然后直接在线安装

BlockUI详细用法_Jquery中ajax加载提示插件blickUI

BlockUI 插件是用于进行AJAX操作时模拟同步传输时锁定浏览器操作。当它被激活时,它会阻止使用者与页面(或页面的一部分)进行交互,直至它被取消。BlockUI以在DOM中添加元素的方法来实现阻止用户与浏览器交互的外观和行为

vue项目中vscode格式化配置和eslint配置冲突

使用vscode开发vue项目的时候,从远端拉下一个新的项目后,安装完依赖后跑起项目时,发现直接报了一堆语法错误:包括换行、空格、单双引号、分号等各种格式问题

点击更多...

内容以共享、参考、研究为目的,不存在任何商业目的。其版权属原作者所有,如有侵权或违规,请与小编联系!情况属实本人将予以删除!