O endereço do github do plug-in do visualizador de arquivos é o seguinte
Cenas
Não usei o visualizador de arquivos diretamente, mas de acordo com o método que pesquisei online, usei apenas a função do visualizador de arquivos para visualizar xlsx e também possui funções como visualizar ppt, pdf e imagens.
Etapa 1: instalar dependências relacionadas (exceljs,)
npm install exceljs --save
npm install '@handsontable/vue' --save
npm install handsontable --save
npm install 'handsontable/i18n' --save //这个依赖我没有下成功,不过也能正常运行
Etapa 2: crie uma nova pasta xlsxView e coloque nela o código xlsx de visualização relevante no visualizador de arquivos.
Etapa 3: abra uma nova janela, introduza e escreva a lógica no componente de visualização
parte html
<template>
<div>
<div v-if="fileType === 'xlsx'" ref="output" />
<div v-if="fileType === 'pptx'" ref="pptRef"></div>
</div>
</template>
parte js
import renderSheet from '../xlsxView'; // 引入
// mounted生命周期
mounted() {
// 从路由地址中获取fileUrl,fileType
this.fileUrl = this.$route.query.fileUrl ? this.$route.query.fileUrl : null
this.fileType = this.$route.query.fileType ? this.$route.query.fileType : null
if (this.fileUrl == null) {
this.$message({
type: 'error',
message: '文件地址无效,请刷新后重试'
})
}
// 加载文件内容
this.uploading(this.fileUrl)
}
// methods方法
methods: {
// 加载文件内容
uploading(file) {
// downloadFileXLS是接口,fileKey传的是文件地址,调接口获取文件流
downloadFileXLS({
fileKey: file}).then(res => {
if(this.fileType === 'xlsx') {
// 预览xlsx
this.displayResult(res)
} else if(this.fileType === 'pptx') {
// 预览pptx,可忽略,该篇文章不涉及pptx的预览
this.previewPptx(res)
}
})
},
displayResult(buffer) {
// 生成新的dom
const node = document.createElement('div')
// 添加孩子,防止vue实例替换dom元素
if (this.last) {
this.$refs.output.removeChild(this.last.$el)
this.last.$destroy()
}
const child = this.$refs.output.appendChild(node)
// 调用渲染方法进行渲染
return new Promise((resolve, reject) =>
renderSheet(buffer, child).then(resolve).catch(reject)
)
}
}
Resumir
Há também uma maneira de usar o luckysheet e o luckyexcel para obter uma visualização do Excel, o link é o seguinte.
O projeto Vue usa luckyexcel para visualizar o formulário do Excel