【vue+elementui】打印dialog彈窗內(nèi)容

難度值:?
需求描述:使用vue+elmentui脉让,打印dialog彈窗里面的內(nèi)容
方法一: PASS
let oldHtml = document.body.innerHTML
document.body.innerHTML = document.getElementById('dialogContent').innerHTML
window.print()
document.body.innerHTML = oldHtml

代碼如上,dialogContent 指代的是需要打印的內(nèi)容區(qū)域柿冲,因為只打印頁面中彈窗內(nèi)的部分,所以將id為dialogContent的div替換了原body的innerHTML,打印后再替換為原本的body

但是在打印過程中壶栋,遇到了一個問題
1、初次打印普监,可以打印頁面贵试,但是打印完畢后,頁面按鈕全部失靈且無法再進行任何操作了

原因:
猜測可能是因為innerHTML造成動態(tài)綁定事件丟失的原因
查資料凯正,大部分建議是使用appendChild()替代innerHTML毙玻,無奈水平有限,嘗試了幾次后還是沒有折騰出來

方法二:vue-print-nb
1. 安裝依賴
cnpm i vue-print-nb -S

2. 在main.js/index.js里面引入
import Print from 'vue-print-nb'
Vue.use(Print)

3. 在需要打印的位置使用
<div id="dialogContent">
  <p style="text-align: center">
    {{ form.status === '條件' ? '標題一' : '標題二' }}
  </p>
  <div class="table-layout">
    <!--內(nèi)容-->
  </div>
</div>

4. 打印
<button v-print="'#dialogContent'">打印</button>

缺點:
只能打印可見區(qū)域廊散,不能分頁打印

方法二:print.js

源碼地址

1. 安裝依賴
cnpm install vuePlugs_printjs -S

2. 引入
import Print from '@/plugins/print'   // 下載到本地地址
Vue.use(Print)

3. 使用
<template>
    <div ref="print">
    <!--打印內(nèi)容-->
    <div class="no-print">不要打印我</div>
    </div>
    <a-button @click="prints">打印</a-button>
</template>
<script>
export default {
  data () {
    return {}
  },
  methods: {
    prints () {
      this.$print(this.$refs.print)
    }
  }
}
</script>

注意:
需使用ref獲取dom節(jié)點桑滩,若直接通過id或class獲取則webpack打包部署后打印內(nèi)容為空

指定不打印區(qū)域
方法一. 添加no-print樣式類

<div class="no-print">不要打印我</div>

方法二. 自定義類名

<div class="do-not-print-me-xxx">不要打印我</div>
this.$print(this.$refs.print,{'no-print':'.do-not-print-me-xxx'}) // 使用
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市允睹,隨后出現(xiàn)的幾起案子运准,更是在濱河造成了極大的恐慌,老刑警劉巖缭受,帶你破解...
    沈念sama閱讀 222,104評論 6 515
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件胁澳,死亡現(xiàn)場離奇詭異,居然都是意外死亡米者,警方通過查閱死者的電腦和手機韭畸,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 94,816評論 3 399
  • 文/潘曉璐 我一進店門宇智,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人胰丁,你說我怎么就攤上這事普筹。” “怎么了隘马?”我有些...
    開封第一講書人閱讀 168,697評論 0 360
  • 文/不壞的土叔 我叫張陵太防,是天一觀的道長。 經(jīng)常有香客問我酸员,道長蜒车,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 59,836評論 1 298
  • 正文 為了忘掉前任幔嗦,我火速辦了婚禮酿愧,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘邀泉。我一直安慰自己嬉挡,他們只是感情好,可當我...
    茶點故事閱讀 68,851評論 6 397
  • 文/花漫 我一把揭開白布汇恤。 她就那樣靜靜地躺著庞钢,像睡著了一般。 火紅的嫁衣襯著肌膚如雪因谎。 梳的紋絲不亂的頭發(fā)上基括,一...
    開封第一講書人閱讀 52,441評論 1 310
  • 那天,我揣著相機與錄音财岔,去河邊找鬼风皿。 笑死,一個胖子當著我的面吹牛匠璧,可吹牛的內(nèi)容都是我干的桐款。 我是一名探鬼主播,決...
    沈念sama閱讀 40,992評論 3 421
  • 文/蒼蘭香墨 我猛地睜開眼夷恍,長吁一口氣:“原來是場噩夢啊……” “哼魔眨!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起裁厅,我...
    開封第一講書人閱讀 39,899評論 0 276
  • 序言:老撾萬榮一對情侶失蹤冰沙,失蹤者是張志新(化名)和其女友劉穎侨艾,沒想到半個月后执虹,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 46,457評論 1 318
  • 正文 獨居荒郊野嶺守林人離奇死亡唠梨,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 38,529評論 3 341
  • 正文 我和宋清朗相戀三年袋励,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 40,664評論 1 352
  • 序言:一個原本活蹦亂跳的男人離奇死亡茬故,死狀恐怖盖灸,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情磺芭,我是刑警寧澤赁炎,帶...
    沈念sama閱讀 36,346評論 5 350
  • 正文 年R本政府宣布,位于F島的核電站钾腺,受9級特大地震影響徙垫,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜放棒,卻給世界環(huán)境...
    茶點故事閱讀 42,025評論 3 334
  • 文/蒙蒙 一姻报、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧间螟,春花似錦吴旋、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,511評論 0 24
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至摩泪,卻和暖如春褂傀,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背加勤。 一陣腳步聲響...
    開封第一講書人閱讀 33,611評論 1 272
  • 我被黑心中介騙來泰國打工仙辟, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人鳄梅。 一個月前我還...
    沈念sama閱讀 49,081評論 3 377
  • 正文 我出身青樓叠国,卻偏偏與公主長得像,于是被迫代替她去往敵國和親戴尸。 傳聞我的和親對象是個殘疾皇子粟焊,可洞房花燭夜當晚...
    茶點故事閱讀 45,675評論 2 359