之前一般做项目进行文件浏览的时候基本都是用的window.open+url的形式打开文件,进行浏览操作的,但是这种打开方式只能够在线浏览如jpg、png、pdf这类文件,对于文档类型docx这种则是用下载的方式打开的。这次甲方爸爸不想要下载了,于是就来使docx-preview这个在线预览组件了。(这个插件只能够实现docx后缀的文件,doc文件打不开滴)
1.下载插件
npm i docx-preview --save
or
yarn add docx-preview
2.导入
import { renderAsync } from 'docx-preview';
//一般用这种形式就行了
let docx = requie('docx-preview');
//我是vue3项目 报错require不行 就用的下边这种了
let docx = import.meta.glob('docx-preview');
3.使用组件
如图有两个文件,设计点击时传送文件file 得到如下数据
因为之前上传时已经限定了上传文件格式,所以通过fileType判断,是图片文件还是docx文档文件,图片文件则直接传url浏览,文档文件则需处理,选择的是将文件通过url地址换成以下这种形式进行操作
要渲染的组件:
<div ref="childRef" class="childRef"></div>
渲染语法:
function previewfile(item) {
if (item.fileType == '.docx') {
nextTick(() => {
fetch(item.filePath)
.then((response) => {
let docData = response.blob(); //将文件转换成bolb形式
//选择要渲染的元素
let childRef = document.getElementsByClassName('childRef');
//用docx-preview渲染
renderAsync(docData, childRef[0]).then((res) => {
console.log('res---->', res);
});
})
.catch((error) => {
console.log(error);
});
});
} else {
ImageUrl.value = toRaw(item).filePath;
}
}
实现结果
这个组件渲染出来有自带的样式,自己修改修改样式就行了