美文网首页前端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 - 打印插件

      本文链接:https://www.haomeiwen.com/subject/zgmzaftx.html