FileViewer 项目Vue2 demo
本demo基于vue-cli+js+vue2.x构建,如果您需要vue3版本的demo,请前往main分支。
适用于Vue2 + Webpack,本集成方法要求最低Webpack版本为5,也就是Vue Cli Service 5.0.0以上,当然,iframe集成没有任何限制
注意,为了版本稳定性,在iframe集成的场景下,无论是vue2版本还是vue3版本,都建议使用file-viewer3以获得最佳性能。
我们针对该项目进行了深度优化,npm仓库搜索 @flyfish-group/file-viewer就可以找到了,最新的是
1.0.4
版本。
方式一:iframe集成(推荐)
iframe集成是我们最推荐的集成方式,可以跳过所有的坑,为您的项目快速集成文件预览能力。
源码准备
下载我们的最新版本的file-viewer源码,然后执行
npm build build
,或者
yarn build
。
构建产物集成
然后将构建后的dist目录拷贝到您项目的public目录下。当然也可以放置到任何项目中。本demo只是演示。
如果您在公网,建议您使用我们的cdn:
以获得高效的访问。
如果您在内网,可以完全参照本demo进行实施。
添加iframe标签
您可以实现一个组件,内部包含一个
<iframe>
标签,接下来您有两种方法进行文件切换。
- 使用url控制切换(推荐)
这种方式是最便捷的实现方式,适合有文件链接的方案。如果你的文件是流式传输或者需要用于上传体验,则不适合该方案。
- 使用postMessage发送文件数据这种方式适合本地上传或者后端返回流式二进制数据。
示例的
IframeViewer.vue
组件实现如下,该组件同时支持两种文件控制方式,您可以直接集成:
<template><iframetitle="文档预览"ref="frame":src="src"class="iframe-viewer"/></template><script>// 查看器的源,当前示例为本源,指定为location.origin即可const viewerOrigin = location.origin;// iframe路径指向构建产物,这里是/,因为放在了public下面// 如果使用cdn,请使用https://viewer.flyfish.devconst source ='/dist/index.html'exportdefault{
name:'IframeViewer',
props:{
url: String,
file: File,
name: String,},mounted(){this.sendFileData();},
computed:{// 构建完整urlsrc(){// 文件名称,建议传递,提高体验性const name =this.name ||'';if(this.url){// 直接拼接urlreturn`${source}?url=${encodeURIComponent(this.url)}&name=${encodeURIComponent(name)}`}elseif(this.file){// 直接拼接来源originreturn`${source}?from=${encodeURIComponent(viewerOrigin)}&name=${encodeURIComponent(name)}`}else{return source;}}},
methods:{// 发送文件数据sendFileData(){this.nextTick(()=>{// iframe引用const viewer =this.$refs.frame;if(!viewer ||!this.file)return;
viewer.onload=()=> viewer.contentWindow?.postMessage(this.file, viewerOrigin);})}}}</script><stylescoped>.iframe-viewer{height:calc(100vh - 2px);width: 100%;border: 0
}</style>
方式二: 使用仓库依赖集成
该方案适合有定制化需求,或者想要控制显示样式或者灵活控制渲染的开发需求。
为了您能够快速集成本项目,我们在中央仓库发布了我们的NPM包。具体地址如下:
- Vue2版本
- Vue3版本
您可以根据项目架构快速选用组件。
以下是示例代码:
main.js
import Vue from'vue'import FileViewer from'@flyfish-group/file-viewer'// 导入样式import'@flyfish-group/file-viewer/dist/style.css'
Vue.use(FileViewer);newVue({render:h=>h(App),}).$mount('#app')
InnerViewer.vue
<template><divclass='simple-view'><file-viewer:url="url"/></div></template><script>exportdefault{
name:'InnerViewer',
props:{
url: String,},}</script><stylescoped>.simple-view{width: 100%;height:calc(100vh - 2px);}</style>
需要注意的是,内置组件
file-viewer
支持使用data的方式传入文件的二进制数据,您可以自行从服务器拉取集成。以下是组件API。
属性名类型示例属性描述fileFile | Blob | ArrayBuffernew Blob(…)支持文件、二进制blob和arraybuffer数组缓存urlString“https://flyfish.dev/1.docx”支持任意服务器文件url,需要支持跨域访问,即存在cors响应头
开源代码下载:
CSDN下载渠道
开源渠道
开源仓库社区:
https://git.flyfish.dev
版权归原作者 小爬的老粉丝 所有, 如有侵权,请联系我们删除。