日本电影一区二区_日本va欧美va精品发布_日本黄h兄妹h动漫一区二区三区_日本欧美黄色

Vue2問題:如何在瀏覽器中導(dǎo)出word文檔?4條解決方案?。╲ue導(dǎo)出文件并瀏覽器下載)

Vue2問題:如何在瀏覽器中導(dǎo)出word文檔?4條解決方案!(vue導(dǎo)出文件并瀏覽器下載)

筆者 | 大澈

大家好,我是大澈!

遇到難題,可以進(jìn)問答群,問題直接群里扔,完事總有人會(huì)陪你一起搞。

Vue2問題:如何在瀏覽器中導(dǎo)出word文檔?4條解決方案!(vue導(dǎo)出文件并瀏覽器下載)

建立這個(gè)平臺(tái)的初衷:

1、打造一個(gè)問答平臺(tái),一個(gè)僅包含前端問題的平臺(tái),讓大家可以高效處理同樣問題。

2、通過不斷積累問題,去練習(xí)大家的個(gè)人邏輯思維,并順便學(xué)習(xí)相關(guān)的知識(shí)點(diǎn)。

3、遇到難題,遇到有共鳴的問題,一起討論,一起沉淀,一起成長(zhǎng)。

ONE

需求分析,問題描述

一、需求

點(diǎn)擊導(dǎo)出word按鈕,將頁面任意指定區(qū)域的內(nèi)容,導(dǎo)出為word文檔。

Vue2問題:如何在瀏覽器中導(dǎo)出word文檔?4條解決方案!(vue導(dǎo)出文件并瀏覽器下載)

二、問題

1、如何獲取指定內(nèi)容?

2、如何將HTML內(nèi)容轉(zhuǎn)換為Word文檔?

3、如何導(dǎo)出下載Word文檔?

TWO

解決問題,答案速覽

實(shí)現(xiàn)代碼如下,復(fù)制粘貼即可直接使用。

如果你有時(shí)間,具體問題梳理、代碼分析、知識(shí)總結(jié),可見第三部分。

一、使用說明

參考網(wǎng)上使用最多的方式,使用 FileSaver.js 和 html-docx-js 庫(kù)(或其它將HTML內(nèi)容轉(zhuǎn)換為Word文檔的庫(kù))來在Vue組件中導(dǎo)出內(nèi)容為Word文檔。

但是這種方式只能在服務(wù)端實(shí)現(xiàn),在瀏覽器端使用會(huì)報(bào)錯(cuò),這是因?yàn)闉g覽器的安全策略限制了對(duì)文件系統(tǒng)的直接訪問,以防止惡意腳本濫用用戶的文件系統(tǒng)。

為了避免報(bào)錯(cuò),您可以考慮以下解決方案:

1、服務(wù)器端導(dǎo)出【推薦】:將生成Word文檔的邏輯放在服務(wù)器端,通過Vue組件向服務(wù)器發(fā)送請(qǐng)求,服務(wù)器生成并返回Word文檔的下載鏈接或文件。

2、使用其他導(dǎo)出方式:考慮使用其他導(dǎo)出方式,例如將內(nèi)容轉(zhuǎn)換為PDF格式或生成Html格式的文件,以避免瀏覽器限制。

3、考慮使用專門的Word文檔生成庫(kù)【導(dǎo)出復(fù)雜Word】:如果您需要在瀏覽器中生成復(fù)雜的Word文檔,可以考慮使用專門的JavaScript庫(kù),例如docxtemplater或mammoth.js,它們提供了更完整的Word文檔生成功能。

4、考慮使用原生的方式實(shí)現(xiàn)【導(dǎo)出簡(jiǎn)單Word】。即我們下面要說的,利用a元素的原生文件下載功能來實(shí)現(xiàn)Word導(dǎo)出。

二、代碼實(shí)例

1、在assets文件夾下新建js文件夾,然后在js文件夾下新建文件exportToWord.js,把下面代碼放進(jìn)去。

// 導(dǎo)出Wordexport const exportToWord = (id, name) => {// 獲取選中區(qū)域Htmlconst dom = document.getElementById(id)const content = dom.innerHTML;const convertedContent = convertToWordDocument(content);// Html類型數(shù)據(jù) 轉(zhuǎn)換為 文件類型數(shù)據(jù)const blob = new Blob([convertedContent], { type: 'application/msword' });// 下載Word文檔const link = document.createElement('a');link.href = URL.createObjectURL(Blob);link.download = name '.doc' || 'exported.doc';link.click();}//完善Html格式const convertToWordDocument = (content) => {const header = `<!DOCTYPE html><html><head><meta charset='utf-8'><title>Exported Document</title></head><body>`;const footer = `</body></html>`;return `${header}${content}${footer}`;}

2、在需要的組件中引入exportToWord函數(shù),直接調(diào)用即可。函數(shù)接收兩個(gè)參數(shù),第一個(gè)是指定區(qū)域元素的id,第二個(gè)是導(dǎo)出Word文檔的名稱。

<template><div><div id="word_demo"><h1>標(biāo)題</h1><p style="color: green">綠色字</p><p style="color: red">紅色字</p><p style="color: dodgerblue">藍(lán)色字</p></div><button @click="downLoad('word_demo', '哈哈哈')">點(diǎn)擊導(dǎo)出word</button></div></template><script>import { exportToWord } from '@/assets/js/exportToWord'export default {methods: {downLoad(id, name) {exportToWord(id, name)},}}</script>

THREE

問題解析,知識(shí)總結(jié)

一、如何獲取指定內(nèi)容?

這個(gè)比較簡(jiǎn)單,相信大家都會(huì),這里簡(jiǎn)單提一下。

對(duì)于組件可以用ref,對(duì)于元素可以用id。

二、如何將HTML內(nèi)容轉(zhuǎn)換為Word文檔?

通過new Blob對(duì)象,將Html類型數(shù)據(jù)轉(zhuǎn)換為生成Word文檔的二進(jìn)制數(shù)據(jù)。

關(guān)于Blob對(duì)象:

1、簡(jiǎn)介:

Blob(Binary Large Object)是JavaScript中的一個(gè)接口,用于表示不可變的、原始數(shù)據(jù)的類似文件的對(duì)象。

它通常用于處理二進(jìn)制數(shù)據(jù),例如圖像、音頻、視頻等。

Blob對(duì)象可以包含任意類型的數(shù)據(jù),包括文本、數(shù)組緩沖區(qū)和其他Blob對(duì)象。

Blob對(duì)象在處理文件上傳、數(shù)據(jù)傳輸和媒體處理等場(chǎng)景中非常有用。您可以將Blob對(duì)象發(fā)送到服務(wù)器、保存到本地文件系統(tǒng)或使用其他API進(jìn)行進(jìn)一步處理。

2、Blob對(duì)象的構(gòu)造函數(shù)接受以下參數(shù):

Blob(blobParts, options):構(gòu)造函數(shù)接受兩個(gè)參數(shù)。

第一個(gè)參數(shù)blobParts是一個(gè)數(shù)組,其中包含將被包含在Blob對(duì)象中的數(shù)據(jù)。數(shù)組的元素可以是字符串、ArrayBuffer、ArrayBufferView、Blob對(duì)象或其他類似對(duì)象。

第二個(gè)參數(shù)options是一個(gè)可選的對(duì)象,用于指定Blob對(duì)象的屬性。

在options參數(shù)中,可以使用以下屬性:

type:指定Blob對(duì)象的MIME類型。默認(rèn)值為空字符串。

endings:指定以何種方式標(biāo)準(zhǔn)化換行符。可能的值是transparent、native和rn。默認(rèn)值是transparent。

3、以下是一些常用的Blob屬性和方法:

屬性:

Blob.size:返回Blob對(duì)象的字節(jié)大小。

Blob.type:返回Blob對(duì)象的MIME類型。

方法:

Blob.slice(start, end, contentType):

創(chuàng)建并返回一個(gè)新的Blob對(duì)象,該對(duì)象包含原始Blob對(duì)象的指定字節(jié)范圍??蛇x參數(shù)contentType用于指定新Blob對(duì)象的MIME類型。

Blob.arrayBuffer():

返回一個(gè)Promise,該P(yáng)romise解析為一個(gè)ArrayBuffer對(duì)象,其中包含Blob對(duì)象的整個(gè)內(nèi)容。

Blob.text():

返回一個(gè)Promise,該P(yáng)romise解析為一個(gè)字符串,其中包含Blob對(duì)象的文本內(nèi)容。

Blob.stream():

返回一個(gè)ReadableStream對(duì)象,可以用于流式讀取Blob對(duì)象的內(nèi)容。

Blob.text():

返回一個(gè)Promise,該P(yáng)romise解析為一個(gè)字符串,其中包含Blob對(duì)象的文本內(nèi)容。

Blob.stream():

返回一個(gè)ReadableStream對(duì)象,可以用于流式讀取Blob對(duì)象的內(nèi)容。

三、如何導(dǎo)出下載Word文檔?

通過a元素的 download 屬性,來實(shí)現(xiàn)文件的導(dǎo)出下載。

在 HTML 中,a元素的 download 屬性用于指定一個(gè)下載鏈接,告訴瀏覽器該鏈接是要被下載而不是在瀏覽器中打開。這樣,當(dāng)用戶點(diǎn)擊鏈接時(shí),瀏覽器會(huì)彈出一個(gè)下載對(duì)話框,提示用戶保存文件到本地設(shè)備。

download 屬性的值可以是一個(gè)文件名,用于指定用戶保存文件時(shí)的默認(rèn)文件名。當(dāng)用戶點(diǎn)擊下載鏈接時(shí),瀏覽器會(huì)使用該值作為默認(rèn)文件名,但用戶仍然可以選擇其他文件名保存。

請(qǐng)注意,download 屬性并不是所有瀏覽器都支持的新特性。特別是在移動(dòng)設(shè)備上,某些瀏覽器可能會(huì)忽略該屬性并在瀏覽器中打開鏈接。因此,在使用 download 屬性時(shí),最好提供一個(gè)備用方案,例如在鏈接的文本或旁邊添加一段說明,告訴用戶右鍵點(diǎn)擊鏈接并選擇 "保存鏈接" 或類似選項(xiàng)來下載文件。

– END –

相關(guān)新聞

聯(lián)系我們
聯(lián)系我們
公眾號(hào)
公眾號(hào)
在線咨詢
分享本頁
返回頂部
栾川县| 墨脱县| 元阳县| 龙口市| 玉林市| 微山县| 宝坻区| 兴文县| 繁峙县| 新昌县| 呼图壁县| 清徐县| 霍城县| 微山县| 裕民县| 乌审旗| 高阳县| 张家界市| 汉沽区| 洛川县| 衡南县| 勃利县| 大丰市| 葵青区| 田东县| 宜兰县| 集贤县| 湖州市| 曲麻莱县| 商城县| 淮阳县| 梁山县| 孟村| 崇州市| 金门县| 彰化县| 弥勒县| 个旧市| 南昌市| 舞阳县| 德兴市|