/vue-simple-print

Easily print any HTML content you you want in Vue. It can be hidden content, certain elements, etc.

Primary LanguageJavaScriptMIT LicenseMIT

Vue Simple Print

This is a Vue2 plugin (easily upgradeable to support Vue3+, just open an issue if the need is there I will do it) that allows you to easily print contents of a specified element. The element can be hidden either through display: none or visibility: hidden and the plugin will still print the contents of the element.

This package has originated from vue-html-to-print and that package originated from vue-html-to-paper.

Why do we need a third option?!

This solution builds upon the previous two solutions by adding additional options like useExistingStylesheets, allowing selection of any valid CSS selector instead of only id attributes, like div[someAttribute="print"] or any other selector. It also provides minified/uglified files, and other code improvements on the two solutions above.

Options

useExistingStylesheets: (default false). When true the plugin will add all of the existing styles and stylesheets from the current page into the printed page. This can be useful if you have custom styling that you want to be applied to the printed document. This will also apply scoped styles!

Demo

Installation

Run the following command npm install simply-print-vue

Usage inside main.js

import Vue from 'vue';
import SimplePrint from 'simply-print-vue';


Vue.use(SimplePrint);
// Alternatively you can pass global options in like this: Vue.use(SimplePrint, { yourOptions: here })

When imported inside of your main.js file, the mixin is callable from your component

<template>
  <div>
    <div>
      <h1>Awesomesauce Page</h1>
    </div>

    <!-- The printable element with the desired contents -->
    <div id="print">
      <p>I'd like to print this paragraph</p>
    </div>

    <button @click="print">Print Paragraph</button>
  </div>
<template>

<script>
  export default {
    methods: {
      print() {
        // Pass your selector in, it can be any valid `querySelector` selector
        async () => await this.$simplePrint('#print');
      }
    }
  }
</script>

Optionally you can apply different options from the global options with each call by defining local options like htis:

this.$simplePrint('print', { localOptions: here });