美文网首页前端rn...vue
vue.js - 打印插件

vue.js - 打印插件

作者: 红薯爱帅 | 来源:发表于2018-10-14 13:28 被阅读30次

1. 概述

如何vue项目中实现打印功能,GitHub上发现一个插件,既优雅又方便。

2. 使用方法

2.1. 注册插件

import Print from '@/plugs/print' // 引入附件的js文件
Vue.use(Print) // 注册

2.2. HTML设置ref,可指定区域打印

<template>
<section ref="print">
    打印内容
    <div class="no-print">不要打印我</div>
</section>
</template>
  • 注意事项,需使用ref获取dom节点,若直接通过id或class获取,则webpack打包部署后打印内容为空。

2.3. 指定不打印区域

  • 方法一. 添加no-print样式类
<div class="no-print">不要打印我</div>
  • 方法二. 自定义类名
<div class="do-not-print-me-xxx">不要打印我</div>
this.$print(this.$ref.print,{'no-print':'.do-not-print-me-xxx'}) // 使用

2.4. 打印

this.$print(this.$refs.print) // 使用

3. 遗留问题

  • 可能通过webpack打包后,打印功能是否可用,需要后续测试下。

4. 附录

print.js

// 打印类属性、方法定义
/* eslint-disable */
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) {
  // 4. 添加实例方法
  Vue.prototype.$print = Print
}
export default MyPlugin

相关文章

  • vue.js - 打印插件

    1. 概述 如何vue项目中实现打印功能,GitHub上发现一个插件,既优雅又方便。 vuePlugs_print...

  • vue高级用法

    Vue 插件 plugin 1, Vue 插件 plugin 安装 Vue.js 插件。如果插件是一个对象,必须提...

  • 我的 Chrome 插件集

    我的 Chrome 插件集 Vue.js devtools vue.js的调试工具 一键管理所有扩展 该插件可以快...

  • 解决安装Vue.js devtools后出现Vue.js not

    在我安装vue.js devtools之后,此插件状态一直是灰色,鼠标防止在此插件上时会显示Vue.js not ...

  • Vue.use解析

    Vue.use 参数:{Object | Function} plugin 用法安装 Vue.js 插件。如果插件...

  • 2018-09-11 vue.js

    vue.js git npm install vue 下载vue.js插件 引用方法