国产 无码 综合区,色欲AV无码国产永久播放,无码天堂亚洲国产AV,国产日韩欧美女同一区二区

vue實(shí)現(xiàn)打印瀏覽器頁面功能(兩種方法)

這篇具有很好參考價(jià)值的文章主要介紹了vue實(shí)現(xiàn)打印瀏覽器頁面功能(兩種方法)。希望對(duì)大家有所幫助。如果存在錯(cuò)誤或未考慮完全的地方,請(qǐng)大家不吝賜教,您也可以點(diǎn)擊"舉報(bào)違法"按鈕提交疑問。

推薦使用方法二

方法一:通過npm 安裝插件

1,安裝 npm install vue-print-nb --save
2,引入 安裝好以后在main.js文件中引入

     import Print from 'vue-print-nb'

Vue.use(Print); //注冊(cè)

3,現(xiàn)在就可以使用了

div id="printTest" >

      <p>明月照于山間</p>

      <p>清風(fēng)來于江上 </p>

    </div>

    <button v-print="'#printTest'">打印</button>     

4.如需通過鏈接地址打?。簑indow.location.href = airway_bill; airway_bill為鏈接地址。

5.如果內(nèi)容打印不全,在打印操作時(shí)點(diǎn)擊更多設(shè)置,然后設(shè)置縮放。

方法一使用時(shí)可能會(huì)遇到內(nèi)容只有一頁,但是點(diǎn)擊打印會(huì)打印2張的情況。解決辦法:查看定義的元素高度是否有被設(shè)置為100%,或html高度被設(shè)置成100%,如果有去掉即可。

方法二:手動(dòng)下載插件到本地

插件地址:https://github.com/xyl66/vuePlugs_printjs
1.在src下新建文件夾plugs,將下載好的print.js放入plugs文件夾下
2.在main.js中引入
print.js 里的代碼

//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) {
    Vue.prototype.$print = Print
  }
  
  export default MyPlugin
  

main.js里引入

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

使用

<template>
    <div>
        <!-- 點(diǎn)擊按鈕打印 -->
        <el-button type="primary" @click="printDemo">點(diǎn)擊打印</el-button>
        
        <!--  <div ref="print">
            <h1>這里是打印內(nèi)容</h1>
        </div>-->
        <img class="printsrcclass" ref='print' :src="printsrc"/>
    </div>    
</template>
<script>

export default {
    data(){
        return {}
    },
    methods: {
        // 點(diǎn)擊打印
        printDemo(){
            setTimeout(() => {
                this.$print(this.$refs.print)
            }, 100);
        }
    },
    mounted() {

    }
}

4.注意事項(xiàng) 需使用ref獲取dom節(jié)點(diǎn),若直接通過id或class獲取則webpack打包部署后打印內(nèi)容為空
5.指定不打印區(qū)域

方法1. 添加no-print樣式類

不要打印我
方法2. 自定義類名

不要打印我
this. p r i n t ( t h i s . 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); // 創(chuàng)建對(duì)象超鏈接
        // 此時(shí)拿到圖片地址 href,后面直接使用該地址即可
        let img = new Image();
        img.src = href;
        img.onload = () => {
          this.printsrc = href;
          this.$nextTick(() => {
            this.mypirntFN();
          })
        }

接口別忘了加類型
vue實(shí)現(xiàn)打印瀏覽器頁面功能(兩種方法)

Ps:

一,可能遇到的問題及解決方案
①圖片占位置 ---------讓它脫離文檔流( position: absolute; 不要用fixed 這樣內(nèi)容多的時(shí)候只打印第一頁)
②頁面不想展示打印內(nèi)容 只打印;------- 給它 z-index:-1 (display:none 的話打印內(nèi)容也沒有)文章來源地址http://www.zghlxwxcb.cn/news/detail-434103.html

  1. 還有其它問題可以留言我看到就回復(fù);
  2. 目前解決不了 跳過打印預(yù)覽直接打印功能 有大佬知道前端實(shí)現(xiàn)功能 請(qǐng)大佬 提供方案

到了這里,關(guān)于vue實(shí)現(xiàn)打印瀏覽器頁面功能(兩種方法)的文章就介紹完了。如果您還想了解更多內(nèi)容,請(qǐng)?jiān)谟疑辖撬阉鱐OY模板網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章,希望大家以后多多支持TOY模板網(wǎng)!

本文來自互聯(lián)網(wǎng)用戶投稿,該文觀點(diǎn)僅代表作者本人,不代表本站立場(chǎng)。本站僅提供信息存儲(chǔ)空間服務(wù),不擁有所有權(quán),不承擔(dān)相關(guān)法律責(zé)任。如若轉(zhuǎn)載,請(qǐng)注明出處: 如若內(nèi)容造成侵權(quán)/違法違規(guī)/事實(shí)不符,請(qǐng)點(diǎn)擊違法舉報(bào)進(jìn)行投訴反饋,一經(jīng)查實(shí),立即刪除!

領(lǐng)支付寶紅包贊助服務(wù)器費(fèi)用

相關(guān)文章

  • 為什么vue打印的對(duì)象在瀏覽器中顯示...

    為什么vue打印的對(duì)象在瀏覽器中顯示...

    1.現(xiàn)象 當(dāng)在vue中打印對(duì)象的時(shí)候會(huì)發(fā)現(xiàn)有一些屬性或者全部屬性都是顯示的...,點(diǎn)擊展開后才能看到真正的值是什么. 2.原因 因?yàn)樵趘ue中對(duì)象都是用了代理重寫了get,由于get重寫也就導(dǎo)致了瀏覽器不能直接獲取到具體的值,因此才會(huì)在打印的時(shí)候?yàn)?..,手動(dòng)點(diǎn)擊展開才顯示具體的值

    2024年04月28日
    瀏覽(31)
  • 實(shí)現(xiàn)微信內(nèi)置瀏覽器分享功能(前期準(zhǔn)備+VUE前端部分代碼+調(diào)試+坑記錄)

    實(shí)現(xiàn)微信內(nèi)置瀏覽器分享功能(前期準(zhǔn)備+VUE前端部分代碼+調(diào)試+坑記錄)

    一、基礎(chǔ)準(zhǔn)備 1、登錄微信公眾號(hào)(需已認(rèn)證),找到[【設(shè)置與開發(fā)】[【公眾號(hào)設(shè)置】【功能設(shè)置】【js接口安全域名],在下面填寫你的域名。 2、在【設(shè)置與開發(fā)】【基本配置】中拿到 appid開發(fā)者密碼 appSecret ,給后端用生成簽名時(shí)用到。 二、前端代碼部分 1、下載微信sdk 2、

    2024年04月17日
    瀏覽(48)
  • vue解決瀏覽器中跳轉(zhuǎn)新頁面緩存上一頁表單等內(nèi)容方法

    vue解決瀏覽器中跳轉(zhuǎn)新頁面緩存上一頁表單等內(nèi)容方法

    在工作中,有可能會(huì)遇到需要緩存頁面或組件的功能。 情況1 :比如在h5中有個(gè)一個(gè)50個(gè)表單,在填到第40個(gè)表單時(shí),需要你去另一個(gè)新頁面去選擇列表項(xiàng),然后把數(shù)據(jù)帶回來。需要我們不僅把數(shù)據(jù)帶回來還要保留前面已經(jīng)填好的40個(gè)表單內(nèi)容不被重置。 此功能在微信小程序是

    2024年02月08日
    瀏覽(19)
  • 【Vue/Js】如何解決谷歌瀏覽器(chrome)擴(kuò)展插件安裝后,再打開自動(dòng)消失問題(兩種解決方案)

    【Vue/Js】如何解決谷歌瀏覽器(chrome)擴(kuò)展插件安裝后,再打開自動(dòng)消失問題(兩種解決方案)

    卸載后,再重新從官網(wǎng)下載最新版安裝。 注意:卸載一定要把緩存數(shù)據(jù)都卸載干凈。 1、打開設(shè)置 ?2、選擇百度或360 極簡(jiǎn)插件_Chrome擴(kuò)展插件商店_優(yōu)質(zhì)crx應(yīng)用 極簡(jiǎn)插件是一個(gè)優(yōu)質(zhì)Chrome插件擴(kuò)展收錄下載網(wǎng)站,收錄熱門好用的Chrome插件擴(kuò)展,國內(nèi)最方便的插件下載網(wǎng)站。 htt

    2024年02月05日
    瀏覽(41)
  • Vue.js中如何使用Vue Router處理瀏覽器返回鍵的功能

    在Vue.js中,Vue Router默認(rèn)提供了處理瀏覽器返回鍵的功能。當(dāng)用戶點(diǎn)擊瀏覽器的返回鍵時(shí),Vue Router會(huì)自動(dòng)導(dǎo)航到歷史記錄中的上一個(gè)路由。然而,如果你想自定義返回鍵的行為或者在特定的頁面上進(jìn)行特殊處理,你可以使用Vue Router的導(dǎo)航守衛(wèi)(Navigation Guards)和Vue的生命周期

    2024年04月10日
    瀏覽(27)
  • UniApp開發(fā)安卓以及H5實(shí)現(xiàn)頁面級(jí)權(quán)限管理,避免用戶瀏覽器直接輸入url訪問頁面

    UniApp開發(fā)安卓以及H5實(shí)現(xiàn)頁面級(jí)權(quán)限管理,避免用戶瀏覽器直接輸入url訪問頁面

    前言:uni-app如何像vue-router中的beforeEach一樣實(shí)現(xiàn)跳轉(zhuǎn)攔截功能呢? 為此uniapp官方提供了專門的API方法?uni.addInterceptor 舉個(gè)栗子 我們發(fā)現(xiàn)底部有四個(gè)菜單分別是:首頁、分類、購物車、我的;按常理來說首頁和分類是不需要登陸就能查看的。另外兩個(gè)則需要先登陸才能查看沒登

    2024年01月16日
    瀏覽(114)
  • Unity內(nèi)打開網(wǎng)頁的兩種方式(自帶瀏覽器、內(nèi)嵌瀏覽器)

    Unity內(nèi)打開網(wǎng)頁的兩種方式(自帶瀏覽器、內(nèi)嵌瀏覽器)

    這個(gè)比較簡(jiǎn)單,直接調(diào)用unity官方的API即可,會(huì)直接使用默認(rèn)瀏覽器打開網(wǎng)頁,這里就不多做解釋了。 代碼 該方案是使用unity store里的插件實(shí)現(xiàn)的。 插件鏈接 使用該插件不會(huì)切出APP。 示例效果 注意此時(shí)是沒有切出游戲的。 測(cè)試代碼 實(shí)現(xiàn)具體需求參考插件文檔即可,還是蠻

    2024年02月05日
    瀏覽(27)
  • Python Selenium 瀏覽器打印預(yù)覽

    在Web開發(fā)中,打印預(yù)覽是一個(gè)常見的功能需求。通過打印預(yù)覽,我們可以預(yù)覽和調(diào)整網(wǎng)頁的打印布局、樣式和內(nèi)容。Python的Selenium庫是一個(gè)強(qiáng)大的工具,可以自動(dòng)化瀏覽器操作,包括打印預(yù)覽。本文將介紹如何使用Python Selenium庫來實(shí)現(xiàn)瀏覽器的打印預(yù)覽功能。 首先,我們需要

    2024年02月03日
    瀏覽(36)
  • 前端:html實(shí)現(xiàn)頁面切換、頂部標(biāo)簽欄,類似于瀏覽器的頂部標(biāo)簽欄(完整版)

    前端:html實(shí)現(xiàn)頁面切換、頂部標(biāo)簽欄,類似于瀏覽器的頂部標(biāo)簽欄(完整版)

    效果 代碼 解決BUG:關(guān)閉單頁時(shí),單頁數(shù)據(jù)未清空,導(dǎo)致再次打開單頁時(shí)出現(xiàn)內(nèi)容仍然存在的問題

    2024年02月11日
    瀏覽(34)
  • 一文搞懂drag&drop瀏覽器拖放功能的實(shí)現(xiàn)

    ? ? ? ?拖放功能,即將一個(gè)元素從一個(gè)區(qū)域,通過拖拽,放置到另一個(gè)區(qū)域。常見的應(yīng)用是將文件或圖片從一個(gè)區(qū)域,拖放到另一個(gè)區(qū)域。中文常常把這表述成拖拽,實(shí)際上拖拽的描述并不準(zhǔn)確,應(yīng)該叫拖放,因?yàn)閐rag事件和drop事件是成對(duì)使用的,即拖拽和放置。 ? ? ? ?

    2024年04月27日
    瀏覽(17)

覺得文章有用就打賞一下文章作者

支付寶掃一掃打賞

博客贊助

微信掃一掃打賞

請(qǐng)作者喝杯咖啡吧~博客贊助

支付寶掃一掃領(lǐng)取紅包,優(yōu)惠每天領(lǐng)

二維碼1

領(lǐng)取紅包

二維碼2

領(lǐng)紅包