# vue-office
**Repository Path**: reference-project_1/vue-office
## Basic Information
- **Project Name**: vue-office
- **Description**: 支持word(.docx)、excel(.xlsx)、pdf等各类型office文件预览的vue组件集合,提供一站式office文件预览方案,支持vue2和3
- **Primary Language**: JavaScript
- **License**: Not specified
- **Default Branch**: master
- **Homepage**: None
- **GVP Project**: No
## Statistics
- **Stars**: 0
- **Forks**: 82
- **Created**: 2025-06-17
- **Last Updated**: 2025-06-17
## Categories & Tags
**Categories**: Uncategorized
**Tags**: None
## README
# vue-office
支持多种文件(docx、pdf、excel)预览的vue组件套装,支持vue2/3。
[查看demo演示](https://501351981.github.io/vue-office/examples/dist/)
## 功能特色
- 一站式:提供docx、pdf、excel多种文档的在线预览方案,有它就够了
- 简单:只需提供文档的src(网络地址)即可完成文档预览
- 体验好:选择每个文档的最佳预览方案,保证用户体验和性能都达到最佳状态
## 安装
```
//docx文档预览组件
npm install @vue-office/docx vue-demi
//excel文档预览组件
npm install @vue-office/excel vue-demi
//pdf文档预览组件
npm install @vue-office/pdf vue-demi
```
## 使用示例
文档预览场景大致可以分为两种:
- 有文档网络地址,比如 https://***.docx
- 文件上传时预览,此时可以获取文件的ArrayBuffer或Blob
### docx文档的预览
**使用网络地址预览**
```vue
```
**上传文件预览**
我们使用element的上传组件作为示例,当然也可以使用普通的input type="file",只要能获取文件的arrayBuffer即可
```vue
点击上传
```
如果是原生的input type="file",也是类似的
```vue
```
### excel文档预览
```vue
```
### pdf文档预览
```vue
```
excel和pdf,也同样支持通过文件上传进行预览,代码和docx的预览一样。
## API
为了使用简单,这几种组件的API尽量保持一致,如果是某个组件特有的,会单独注明
### 属性
| 属性 | 说明 | 类型 | 可选值 | 默认值 |
|-----------------|--------------------------------------------|---------------------------|----------------|-----|
| src | 文档地址 | String, ArrayBuffer, Blob | - | - |
| request-options | 请求参数,对应window.fetch的请求参数,可以用来设置header等请求信息 | Object | 参考window.fetch | {} |
### 事件
| 事件名 | 说明 | 参数 |
|----------|-----------------------------|-----------|
| rendered | 首次渲染完成及每次src变化之后渲染完成都会触发该事件 | |
| error | 各种失败,包括网络请求失败,渲染失败等 | errorInfo |
## 交流反馈
### 提Issue
如果您遇到了问题,欢迎提Issue,同时请您尽可能详细的描述您遇到的问题,包括不限于
- 您使用的是哪个库: @vue-office/docx、@vue-office/excel、@vue-office/pdf
- 您使用的环境:APP or Web,PC or 移动端,如果是浏览器兼容问题,请提供您的浏览器版本
- 如果有错误,请粘贴详细的报错信息
详细的描述有助于我尽快定位问题,因为平时工作很忙,时间很有限,感谢理解
### 赞助和微信交流
**_如果该项目确实帮助到了您_**,欢迎赞助,以鼓励我将更多的休息时间,投入到该项目的优化中,也欢迎赞助后添加微信交流:\_hit757_
### 恳请各位大佬不吝点赞,开源不易,感谢过往各位大佬的支持~~