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

前端實(shí)現(xiàn)文件預(yù)覽(pdf、excel、word、圖片)

這篇具有很好參考價(jià)值的文章主要介紹了前端實(shí)現(xiàn)文件預(yù)覽(pdf、excel、word、圖片)。希望對(duì)大家有所幫助。如果存在錯(cuò)誤或未考慮完全的地方,請(qǐng)大家不吝賜教,您也可以點(diǎn)擊"舉報(bào)違法"按鈕提交疑問。

前端實(shí)現(xiàn)文件預(yù)覽功能

需求:實(shí)現(xiàn)一個(gè)在線預(yù)覽pdf、excel、word、圖片等文件的功能。
介紹:支持pdf、xlsx、docx、jpg、png、jpeg。
以下使用Vue3代碼實(shí)現(xiàn)所有功能,建議以下的預(yù)覽文件標(biāo)簽可以在外層包裹一層彈窗。

圖片預(yù)覽?

<iframe  :src="圖片地址"
         style="z-index: 1000; height:650px; width: 100%; margin: 0 auto"
         sandbox="allow-scripts allow-top-navigation allow-same-origin allow-popups"
>

sandbox 這個(gè)屬性如果是單純預(yù)覽圖片可以不使用,該屬性對(duì)呈現(xiàn)在 iframe 框架中的內(nèi)容啟用一些額外的限制條件。屬性值可以為空字符串(這種情況下會(huì)啟用所有限制),也可以是用空格分隔的一系列指定的字符串。

  • allow-scripts: 允許嵌入的瀏覽上下文運(yùn)行腳本(但不能創(chuàng)建彈窗)。如果沒有使用該關(guān)鍵字,就無法運(yùn)行腳本。
  • allow-top-navigation: 允許將框架內(nèi)所加載頁面中的超鏈接導(dǎo)航到父級(jí)窗口
  • allow-same-popups: 允許彈窗 (例如 window.open, target="_blank")。如果沒有使用該關(guān)鍵字,相應(yīng)的功能將自動(dòng)被禁用。
  • allow-same-origin: 如果沒有使用該關(guān)鍵字,嵌入的瀏覽上下文將被視為來自一個(gè)獨(dú)立的源,這將使 same-origin policy 同源檢查失敗。使用了這個(gè)屬性,那么當(dāng)前頁面和iframe打開的頁面視為同源。

word文檔預(yù)覽(docx)

先下載npm包
npm i docx-preview --save
<div class="docxRef"></div>

<script>
import { renderAsync } from 'docx-preview';

function fn() {
// 這里的res.data是 blob文件流,如果自己的不是blob文件流
// 可以通過URL.createObjectURL(參數(shù)) 參數(shù)為File格式,轉(zhuǎn)換為blob文件流
    let blob = res.data
    let childRef = document.getElementsByClassName('docxRef');
    renderAsync(blob, childRef[0]) //渲染
}
fn()

</script>

blob文件流

前端預(yù)覽文件,pdf,excel,word,vue.js,前端

?預(yù)覽excel文件(xlsx)

下載包
npm install xlsx@0.16.0
<div class="xlsxClass"></div>

const reader = new FileReader();
//通過readAsArrayBuffer將blob轉(zhuǎn)換為ArrayBuffer對(duì)
reader.readAsArrayBuffer(res.data) // 這里的res.data是blob文件流
reader.onload = (event) => {
  // 讀取ArrayBuffer數(shù)據(jù)變成Uint8Array
  var data = new Uint8Array(event.target.result);
  // 這里的data里面的類型和后面的type類型要對(duì)應(yīng)
  var workbook = XLSX.read(data, { type: "array" });
  var sheetNames = workbook.SheetNames; // 工作表名稱
  var worksheet = workbook.Sheets[sheetNames[0]];
  // var excelData = XLSX.utils.sheet_to_json(worksheet); //JSON
  let html = XLSX.utils.sheet_to_html(worksheet);
  document.getElementsByClassName('xlsxClass')[0].innerHTML = html
};

pdf預(yù)覽

下載包 npm install pdfjs-dist
我使用的是npm install pdfjs-dist@2.0.943版本,以下例子使用的是vue3+vite創(chuàng)建的項(xiàng)目
以下例子通過canvas來渲染pdf
<template>
  <div class="box">
    <div class="tool-bar">
      <div>{{ pdfParams.pageNumber }} / {{ pdfParams.total }}</div>
      <button type="primary" :disabled="pdfParams.pageNumber == pdfParams.total" @click="nextPage">下一頁
      </button>
      <button type="primary" :disabled="pdfParams.pageNumber == 1" @click="prevPage">上一頁</button>
    </div>
    <canvas id="pdf-render"></canvas>
  </div>
</template>

<script setup>
import { onMounted, ref, reactive } from 'vue'
const pdfParams = reactive({
  pageNumber: 1, // 當(dāng)前頁
  total: 0, // 總頁數(shù)
});

// 不要定義為ref或reactive格式,就定義為普通的變量
let pdfDoc = null;
// 這里必須使用異步去引用pdf文件,直接去import會(huì)報(bào)錯(cuò),也不知道為什么
onMounted(async ()=> {
  let pdfjs = await import('pdfjs-dist/build/pdf')
  let pdfjsWorker = await import('pdfjs-dist/build/pdf.worker.entry')
  pdfjs.GlobalWorkerOptions.workerSrc = pdfjsWorker
  // 此文件位于public/test2.pdf
  let url = ref('/test2.pdf')
  pdfjs.getDocument(url.value).promise.then(doc => {
    pdfDoc = doc
    pdfParams.total = doc.numPages
    getPdfPage(1)
  })
})

// 加載pdf的某一頁
const getPdfPage = (number) => {
  pdfDoc.getPage(number).then(page => {
    const viewport = page.getViewport()
    const canvas = document.getElementById('pdf-render')
    const context = canvas.getContext('2d')
    canvas.width = viewport.viewBox[2]
    canvas.height = viewport.viewBox[3]
    viewport.width = viewport.viewBox[2]
    viewport.height = viewport.viewBox[3]
    canvas.style.width = Math.floor(viewport.width) + 'px'
    canvas.style.height = Math.floor(viewport.height) + 'px'

    let renderContext = {
      canvasContext: context,
      viewport: viewport,
      // 這里transform的六個(gè)參數(shù),使用的是transform中的Matrix(矩陣)
      transform: [1, 0, 0, -1, 0, viewport.height]
    }
    // 進(jìn)行渲染
    page.render(renderContext)
  })
}
// 下一頁功能
const prevPage = () => {
  if(pdfParams.pageNumber > 1) {
    pdfParams.pageNumber -= 1
  } else {
    pdfParams.pageNumber  = 1
  }
  getPdfPage(pdfParams.pageNumber)
}
// 上一頁功能
const nextPage = () => {
  if(pdfParams.pageNumber < pdfParams.total) {
    pdfParams.pageNumber += 1
  } else {
    pdfParams.pageNumber = pdfParams.total
  }
  getPdfPage(pdfParams.pageNumber)
}
</script>

以上pdf代碼引用文章:(54條消息) 前端pdf預(yù)覽、pdfjs的使用_pdf.js_無知的小菜雞的博客-CSDN博客
pdfjs官方代碼:例子 (mozilla.github.io)
以上代碼看不懂的地方可以查閱官方代碼,大部分都是固定的寫法。

前端預(yù)覽文件,pdf,excel,word,vue.js,前端

以上注意點(diǎn):文章來源地址http://www.zghlxwxcb.cn/news/detail-690664.html

  • 必須異步引用pdf的文件?。?!
  • pdf演示文件位于public/test2.pdf
  • transform: [1, 0, 0, -1, 0, viewport.height],使用了transform中的Matrix(矩陣)
  • 下一頁和上一頁功能都需要重新渲染

到了這里,關(guān)于前端實(shí)現(xiàn)文件預(yù)覽(pdf、excel、word、圖片)的文章就介紹完了。如果您還想了解更多內(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)文章

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

支付寶掃一掃打賞

博客贊助

微信掃一掃打賞

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

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

二維碼1

領(lǐng)取紅包

二維碼2

領(lǐng)紅包