返回顶部
首页 > 资讯 > 前端开发 > JavaScript >vue打印浏览器页面功能的两种实现方法
  • 562
分享到

vue打印浏览器页面功能的两种实现方法

摘要

目录方法一:通过npm 安装插件方法二:手动下载插件到本地总结推荐使用方法二 方法一:通过npm 安装插件 1,安装 npm install Vue-print-nb --save

推荐使用方法二

方法一:通过npm 安装插件

1,安装 npm install Vue-print-nb --save

2,引入 安装好以后在main.js文件中引入

     import Print from 'vue-print-nb'

Vue.use(Print); //注册

3,现在就可以使用了

div id="printTest" >
      <p>明月照于山间</p>
      <p>清风来于江上 </p>
    </div>
    <button v-print="'#printTest'">打印</button>

4.如需通过链接地址打印:window.location.href = airway_bill; airway_bill为链接地址。

5.如果内容打印不全,在打印操作时点击更多设置,然后设置缩放。

方法一使用时可能会遇到内容只有一页,但是点击打印会打印2张的情况。解决办法:查看定义的元素高度是否有被设置为100%,或html高度被设置成100%,如果有去掉即可。

方法二:手动下载插件到本地

插件地址:https://GitHub.com/xyl66/vuePlugs_printjs

1.在src下新建文件夹plugs,将下载好的print.js放入plugs文件夹下

2.在main.js中引入

print.js 里的代码

//print.js 里的代码
// 打印类属性、方法定义

const Print =function(dom, options) {
    if (!(this instanceof Print)) return new Print(dom, options);
  
    this.options = this.extend({
      'noPrint': '.no-print'
    }, options);
  
    if ((typeof dom) === "string") {
      this.dom = document.querySelector(dom);
    } else {
      this.dom = dom;
    }
  
    this.init();
  };
  Print.prototype = {
  
    init: function () {
      var content = this.getStyle() + this.gethtml();
      this.writeIframe(content);
    },
    
    extend: function (obj, obj2) {
      for (var k in obj2) {
        obj[k] = obj2[k];
      }
      return obj;
    },
  
    getStyle: function () {
      var str = "",
        styles = document.querySelectorAll('style,link');
      for (var i = 0; i < styles.length; i++) {
        str += styles[i].outerHTML;
      }
      str += "<style>" + (this.options.noPrint ? this.options.noPrint : '.no-print') + "{display:none;}</style>";
  
      return str;
    },
  
    getHtml: function () {
      var inputs = document.querySelectorAll('input');
      var textareas = document.querySelectorAll('textarea');
      var selects = document.querySelectorAll('select');
  
      for (var k in inputs) {
        if (inputs[k].type == "checkbox" || inputs[k].type == "radio") {
          if (inputs[k].checked == true) {
            inputs[k].setAttribute('checked', "checked")
          } else {
            inputs[k].removeAttribute('checked')
          }
        } else if (inputs[k].type == "text") {
          inputs[k].setAttribute('value', inputs[k].value)
        }
      }
  
      for (var k2 in textareas) {
        if (textareas[k2].type == 'textarea') {
          textareas[k2].innerHTML = textareas[k2].value
        }
      }
  
      for (var k3 in selects) {
        if (selects[k3].type == 'select-one') {
          var child = selects[k3].children;
          for (var i in child) {
            if (child[i].tagName == 'OPTION') {
              if (child[i].selected == true) {
                child[i].setAttribute('selected', "selected")
              } else {
                child[i].removeAttribute('selected')
              }
            }
          }
        }
      }
  
      return this.dom.outerHTML;
    },
  
    writeIframe: function (content) {
      var w, doc, iframe = document.createElement('iframe'),
          f = document.body.appendChild(iframe);
      iframe.id = "myIframe";
      iframe.style = "position:absolute;width:0;height:0;top:-10px;left:-10px;";
      
      w = f.contentWindow || f.contentDocument;
      doc = f.contentDocument || f.contentWindow.document;
      doc.open();
      doc.write(content);
      doc.close();
      this.toPrint(w);
      
      setTimeout(function () {
        document.body.removeChild(iframe)
      }, 100)
    },
    
    toPrint: function (frameWindow) {
      try {
        setTimeout(function () {
          frameWindow.focus();
          try {
            if (!frameWindow.document.execCommand('print', false, null)) {
              frameWindow.print();
            }
          } catch (e) {
            frameWindow.print();
          }
          frameWindow.close();
        }, 10);
      } catch (err) {
        console.log('err', err);
      }
    }
  };
  
  const MyPlugin = {}
  MyPlugin.install = function (Vue, options) {
    Vue.prototype.$print = Print
  }
  
  export default MyPlugin

main.js里引入

import Print from './plugs/print'
Vue.use(Print)

使用

<template>
    <div>
        <!-- 点击按钮打印 -->
        <el-button type="primary" @click="printDemo">点击打印</el-button>
        
        <!--  <div ref="print">
            <h1>这里是打印内容</h1>
        </div>-->
        <img class="printsrcclass" ref='print' :src="printsrc"/>
    </div>    
</template>
<script>

export default {
    data(){
        return {}
    },
    methods: {
        // 点击打印
        printDemo(){
            setTimeout(() => {
                this.$print(this.$refs.print)
            }, 100);
        }
    },
    mounted() {

    }
}

4.注意事项 需使用ref获取dom节点,若直接通过id或class获取则webpack打包部署后打印内容为空

5.指定不打印区域

方法1. 添加no-print样式类

不要打印我

方法2. 自定义类名

不要打印我

this. print (this . print(this. print(this.refs.print,{‘no-print':‘.do-not-print-me-xxx'}) // 使用

如果图片出不来 打印出不来 等情况

参考下面代码

const res2 = await fnapi(orderId);
 let myBlob = new Blob([res2.data], { type: 'image/jpeg'});
        var href = URL.createObjectURL(myBlob); // 创建对象超链接
        // 此时拿到图片地址 href,后面直接使用该地址即可
        let img = new Image();
        img.src = href;
        img.onload = () => {
          this.printsrc = href;
          this.$nextTick(() => {
            this.mypirntFN();
          })
        }

接口别忘了加类型

Ps:

一,可能遇到的问题及解决方案

①图片占位置 ---------让它脱离文档流( position: absolute; 不要用fixed 这样内容多的时候只打印第一页)

②页面不想展示打印内容 只打印;------- 给它 z-index:-1 (display:none 的话打印内容也没有)

目前解决不了 跳过打印预览直接打印功能 

总结

到此这篇关于vue打印浏览器页面功能的两种实现方法的文章就介绍到这了,更多相关vue打印浏览器页面功能内容请搜索编程网以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程网!

--结束END--

本文标题: vue打印浏览器页面功能的两种实现方法

本文链接: https://lsjlt.com/news/209304.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • vue打印浏览器页面功能的两种实现方法
    目录方法一:通过npm 安装插件方法二:手动下载插件到本地总结推荐使用方法二 方法一:通过npm 安装插件 1,安装 npm install vue-print-nb --save...
    99+
    2023-05-15
    vue实现打印预览功能 vue实现打印预览功能 vue 打印预览
  • vue怎么打印浏览器页面功能
    这篇文章主要介绍“vue怎么打印浏览器页面功能”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“vue怎么打印浏览器页面功能”文章能帮助大家解决问题。方法一:通过npm 安装插件1,安装 npm ins...
    99+
    2023-07-06
  • vue实现页面打印自动分页的两种方法
    本文实例为大家分享了vue实现页面打印自动分页的具体代码,供大家参考,具体内容如下 一、通过ref方式获取元素进行打印 1.封装一个js文件 // 打印类属性、方法定义 con...
    99+
    2024-04-02
  • vue打印功能实现的两种方法总结
    第一种方法:通过npm 安装插件 1,安装 npm install vue-print-nb --save 2,引入 安装好以后在main.js文件中引入 import...
    99+
    2024-04-02
  • 前端实现打印功能的两种方法详解
    目录前言方法一:window.print()   方法二:利用iframe,iframe.contentWindow.print()补充:导出步骤总结:前言 前端...
    99+
    2023-01-06
    前端实现打印功能 前端打印语句 前端打印功能实现
  • window.print()打印html网页的两种方法实现
    目录一、编辑打印区域二:将不需要打印的部分隐藏一、编辑打印区域 思路: 通过编辑打印的开始、结束标记来区分打印的区域 HTML: <!--startprint--> &l...
    99+
    2024-04-02
  • JS如何实现页面打印功能
    小编给大家分享一下JS如何实现页面打印功能,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!打印整个页面示例1.可直接在按钮添加调用...
    99+
    2024-04-02
  • vue中使用pdfjs-dist + turnjs实现页面的翻书浏览功能
    目录首先 安装 psfjs-distvue中安装jquery的方法下载trunjspdfjs-dist 的工作原理:把获取到的 pbf 的文件的数据流, 利用 canvas转换成图片...
    99+
    2022-11-13
    vue页面的翻书浏览 vue使用pdfjs-dist vue turnjs翻书
  • php怎么实现Web页面的打印功能
    PHP 打印功能实现的步骤和技巧 在 Web 开发的过程中,打印功能是相当重要的一种需求。相信大家都遇到过需要从网页中打印出某些内容的情况,比如收据、报告、合同等。本文将介绍如何使用 PHP 实现 Web 页面的打印功能。下面,我们...
    99+
    2023-05-14
    php 打印
  • php如何实现Web页面的打印功能
    这篇文章主要讲解了“php如何实现Web页面的打印功能”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“php如何实现Web页面的打印功能”吧!下面,我们先简单介绍一下能够实现打印功能的基本知识...
    99+
    2023-07-05
  • Vue实现浏览器端扫码功能
    背景 不久前我做了关于获取浏览器摄像头并扫码识别的功能,本文中梳理了涉及到知识点及具体代码实现,整理成此篇文章内容。 本文主要介绍,通过使用基于 vue 技术栈的前端开发技术,在浏...
    99+
    2024-04-02
  • vue中的vue-print-nb如何实现页面打印
    目录安装在main.js中全局引入页面中使用安装 npm install vue-print-nb --save 在main.js中全局引入 import Print from 'v...
    99+
    2024-04-02
  • JavaScript实现简易计算器功能的两种方法
    本文实例为大家分享了两种JavaScript实现简易计算器功能的具体代码,供大家参考,具体内容如下 1. 使用基本数据类型 注意点: prompt 用户从浏览器输入的任何数据都是字符...
    99+
    2024-04-02
  • php实现分页功能的3种方法
    1. 使用数据库的LIMIT语句实现分页功能。这种方法是最常见的,通过在SQL语句中添加LIMIT子句来指定每页显示的记录数和偏移量...
    99+
    2023-08-14
    php
  • 如何进行CRM WebClient UI的浏览器打印实现
    如何进行CRM WebClient UI的浏览器打印实现,相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。WebClient UI上自带了一个打印按钮,按Ctrl + P后可以生成...
    99+
    2023-06-04
  • Python实现打印螺旋矩阵功能的方法
    本文实例讲述了Python实现打印螺旋矩阵功能的方法。分享给大家供大家参考,具体如下: 一、问题描述 输入N, 打印 N*N 螺旋矩阵 比如 N = 3,打印: 1 2 3 8 9 4 7 6 5 N...
    99+
    2022-06-04
    矩阵 螺旋 功能
  • vue实战:打印小票的实现方法
    vue也能实现打印小票?下面本篇文章就带大家详细了解一下怎么通过安装 lodop 打印控件,实现打印小票,本文附有详细实例代码哦,希望对大家有所帮助!lodop 打印控件安装 lodop 打印控件lodop地址: http://www.c-...
    99+
    2023-05-14
    Vue
  • Vue 页面监听用户预览时间功能的实现代码
    最近的业务中涉及到这样一个需求,在线培训的系统需要知道用户对某个在线预览的页面追踪用户的预览时长。初步我们首先想到借助 Vue 页面的生命周期函数 mounted 和 destroy...
    99+
    2024-04-02
  • Vue页面监听用户预览时间功能如何实现
    这篇文章主要介绍“Vue页面监听用户预览时间功能如何实现”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“Vue页面监听用户预览时间功能如何实现”文章能帮助大家解决问题...
    99+
    2024-04-02
  • Vue页面监听用户预览时间功能怎么实现
    这篇文章主要介绍“Vue页面监听用户预览时间功能怎么实现”,在日常操作中,相信很多人在Vue页面监听用户预览时间功能怎么实现问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”Vu...
    99+
    2024-04-02
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作