web前端结合Microsoft Office Online 在线预览,vue实现(PPT、Word、Excel、PDF等)

web前端结合Microsoft Office Online 在线预览,vue实现(PPT、Word、Excel、PDF等)

什么是 Microsoft Office Online 预览服务

Microsoft Office Online 预览服务是由微软提供的免费在线文档预览工具,通过简单的 URL 参数配置,即可在网页中嵌入并预览各种 Office 文档和 PDF 文件,无需安装任何桌面软件。

demo地址:: https://gitee.com/huang_zhan_le/preview-office

核心预览链接格式:

https://view.officeapps.live.com/op/embed.aspx?src=[文件URL]

核心代码实现

在我们的项目中,通过 OfficeViewer 类封装了对该服务的调用。以下是核心实现代码:

/*** 生成Microsoft Office Online Viewer URL* Microsoft官方提供的Office文档在线预览服务* 支持格式最全面,包括Word、Excel、PowerPoint、PDF等* * @param encodedUrl - 编码后的文件URL* @returns Microsoft预览服务URL*/
private generateMicrosoftUrl(encodedUrl: string): string {return `https://view.officeapps.live.com/op/embed.aspx?src=${encodedUrl}`;
}

使用方法

基本用法

  1. 导入 OfficeViewer
  2. 创建预览器实例
  3. 生成预览 URL
  4. 在页面中嵌入预览
// 1. 导入插件
import OfficeViewer from '@/utils/officeViewer'// 2. 创建预览器实例
const viewer = new OfficeViewer()// 3. 生成预览URL
const previewUrl = viewer.generateViewerUrl('https://example.com/document.pdf')// 4. 在模板中使用
<iframe :src="previewUrl" width="100%" height="600px"></iframe>

直接使用 URL

也可以直接在 HTML 中使用预览 URL:

<iframe src="https://view.officeapps.live.com/op/embed.aspx?src=https://example.com/document.pdf"width="100%" height="600px"frameborder="0"
></iframe>

支持的文件类型

Microsoft Office Online 预览服务支持以下文件类型:

  • Word 文档: .doc, .docx
  • Excel 表格: .xls, .xlsx
  • PowerPoint 演示: .ppt, .pptx
  • PDF 文档: .pdf
  • 文本文件: .txt
  • 富文本文件: .rtf
  • OpenDocument 格式: .odt, .ods, .odp

高级功能

1. 切换预览服务

OfficeViewer 类支持切换不同的预览服务,包括 Microsoft、Google 和自定义服务:

// 创建预览器实例,指定使用Google服务
const viewer = new OfficeViewer({ service: 'google' })// 动态切换服务
viewer.updateConfig({ service: 'microsoft' })

2. 文件验证

可以验证文件是否支持预览:

import { FileUploader } from '@/utils/officeViewer'// 验证文件
const validation = FileUploader.validateFile(file)
if (validation.valid) {console.log('文件验证通过')
} else {console.error('文件验证失败:', validation.message)
}

3. 本地文件预览

对于本地文件,可以创建临时 URL 进行预览:

// 为本地文件创建预览URL
const objectUrl = FileUploader.createObjectURL(file)
const previewUrl = viewer.generateViewerUrl(objectUrl)// 使用完毕后释放资源
FileUploader.revokeObjectURL(objectUrl)

实际应用示例

以下是在 Vue 组件中使用 Office 预览服务的完整示例:

<template><div class="office-viewer"><h3>文档预览</h3><div v-if="previewUrl" class="preview-container"><iframe :src="previewUrl"width="100%" height="600px"frameborder="0"></iframe></div><div v-else><el-button @click="generatePreview" type="primary">生成预览</el-button></div></div>
</template><script setup lang="ts">
import { ref } from 'vue';
import OfficeViewer from '@/utils/officeViewer';const previewUrl = ref('');
const viewer = new OfficeViewer({ service: 'microsoft' });const generatePreview = () => {const fileUrl = 'https://example.com/document.pdf';previewUrl.value = viewer.generateViewerUrl(fileUrl);
};
</script>

注意事项

  1. 文档 URL 必须是公开可访问的,否则无法预览
  2. 对于大型文档,预览可能需要一定时间加载
  3. 某些高级格式特性可能在预览中无法完全显示
  4. 确保遵守 Microsoft Office Online 服务的使用条款

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如若转载,请注明出处:http://www.pswp.cn/diannao/94654.shtml
繁体地址,请注明出处:http://hk.pswp.cn/diannao/94654.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

安卓手机用久了会出现卡顿,为什么?

安卓手机用久了出现卡顿&#xff0c;主要与内存不足、系统机制特性、硬件老化、软件冲突与冗余、使用习惯不当五大核心因素相关。以下是具体原因及针对性解决方案&#xff1a;一、卡顿核心原因分析内存不足运行内存&#xff08;RAM&#xff09;被占用&#xff1a;安卓应用默认在…

以 Eland 玩转 Elasticsearch 8.12 Learning-to-Rank

1 为什么要在 Elasticsearch 上做 LTR&#xff1f; 适用版本&#xff1a; Elasticsearch ≥ 8.12.0 前置条件&#xff1a; 需拥有包含 “Serverless LTR” 的订阅等级&#xff08;详见官方订阅矩阵&#xff09; 技术栈&#xff1a; Elasticsearch Python Eland XGBoost / Li…

OpenCV入门:图像处理基础教程

OpenCV简介 OpenCV&#xff08;Open Source Computer Vision Library&#xff09;是一个开源的计算机视觉和机器学习库。它包含超过2500种优化算法&#xff0c;涵盖图像处理、物体识别、人脸检测、3D重建、视频分析等任务。 核心功能 图像处理&#xff1a;滤波、边缘检测、几…

影响内容传播速度的因素有哪些?

内容的传播速度是我们在衡量营销效果时的重要指标。传播速度越快&#xff0c;越能帮助品牌迅速覆盖目标受众&#xff0c;在短时间内提升影响力。影响内容传播速度的方式来自多个方面&#xff0c;下面就让我们一同来了解下这其中的因素。一、观点价值观点是否具有价值&#xff0…

css动态样式

使用scss通过变量设置css动态样式<template><div><!-- 方式一 --><p v-for"(item, index) in dataList" :key"index" :style"{--color: item.color}" >{{item.name}}</p><!-- 方式二 --><p v-for"(…

开源流媒体服务器ZLMediaKit 的Java Api实现的Java版ZLMediaKit流媒体服务器-二开视频对话

安全性&#xff1a;使用了WSS&#xff08;WebSocket Secure&#xff09;协议确保通信安全 兼容性&#xff1a;支持现代浏览器的WebRTC功能 信令机制&#xff1a;通过WebSocket进行信令交换&#xff0c;确保连接建立 媒体传输&#xff1a;使用STUN服务器进行NAT穿透&#xff0c;…

mariadb10.3.35备份脚本

一、创建备份用户[(none)]> create user buserlocalhost identified by tmrQ;[(none)]> GRANT RELOAD, PROCESS, LOCK TABLES, REPLICATION CLIENT ON *.* TO buserlocalhost;[(none)]> flush privileges;二、脚本# cat mysql_bask.sh #!/bin/bash # MariaDB 10.3.35…

W3D引擎游戏开发----从入门到精通【22】

配置完成基本DT物体项后&#xff0c;在这个DT物体项中开始添加这个玩家的动画信息&#xff0c;如下所示。UseAnim设置是否使用动画功能&#xff0c;这里开启。AnimTypeN设置总共的动画类型数&#xff0c;当前只有一个待机动画&#xff0c;因此设置为1。AnimType1FrameN设置1号动…

在我国申请注册的商标在国外可以用不!

近日一个网友找到普推知产商标老杨&#xff0c;问在我国申请注册商标在新加坡和欧盟可以用不&#xff0c;当然用不成&#xff0c;根据商标法的地域性原则&#xff0c;商标权保护限于注册地&#xff0c;驰名商标享有部分跨国保护&#xff0c;但是这个要有所在国相关法律证据。如…

在开发板上画出一个2048棋盘的矩阵

#include “head.h"int* p lcd NULL; //显示屏内存映射的起始地址int g lcd width; //LCD显示屏的宽度int g lcd high ; //LCD显示屏的高度int g lcd bpp; //每个像素点所占的比特位//int x:屏的X轴&#xff08;宽度、列&#xff09;坐标//int y:屏幕y轴&#xff08;高度、…

开源软件与文化:从嬉皮士精神到数字时代的协同创新

开源软件与文化&#xff1a;从嬉皮士精神到数字时代的协同创新 本文章由笔者使用提示词驱动AI创作&#xff0c;并进行审阅。 文章目录开源软件与文化&#xff1a;从嬉皮士精神到数字时代的协同创新一、引言&#xff1a;开源的文化基因与技术革命二、开源软件的文化根源&#x…

sigfillset 函数详解

sigfillset 函数详解 一、函数概念 sigfillset() 是 POSIX 信号处理中的核心函数&#xff0c;用于初始化并填充一个信号集&#xff0c;使其包含当前系统支持的所有信号。它是操作信号屏蔽字&#xff08;signal mask&#xff09;的基础工具&#xff0c;常与 sigprocmask()、sigs…

Redis实战(8) -- 分布式锁Redission底层机制

介绍Redisson 是基于 Redis 实现的 Java 驻内存数据网格&#xff08;In-Memory Data Grid&#xff09;&#xff0c;提供了分布式和可扩展的 Java 数据结构&#xff0c;如分布式锁、分布式集合等。【注意】如果需要重新实现redission&#xff0c;需要重新设置RedissionClient配置…

Linux基础测试

linux基础测试 一、环境准备 基础环境信息 登录用户&#xff1a;root&#xff08;初始密码&#xff1a;redhat&#xff09; 虚拟机启动&#xff1a;登录后执行 virt-manager&#xff0c;右键启动 node1 和 node2 虚拟机 node1 信息&#xff1a;root 密码为 redhat&#xf…

Linux中Docker Swarm实践

一、部署前后分离使用你自己的自定义镜像部署多个副本所有副本使用相同的配置和逻辑Nginx 做反向代理统一入口外部访问形式如&#xff1a;http://your-domain/api/xxx1.1 建立私库镜像已构建并推送到可访问的镜像仓库启动 Docker Registry 容器docker run -d -p 5000:5000 --re…

Dash 中的 dcc.Clipboard 组件详解:实现一键复制功能

dcc.Clipboard 是 Dash 核心组件库中的一个实用工具&#xff0c;允许用户将指定内容一键复制到系统剪贴板&#xff0c;极大提升用户体验。本文将深入解析该组件的用法、特性和实际应用场景。 一、组件核心功能与价值 dcc.Clipboard 解决了 Web 应用中的关键痛点&#xff1a; 简…

初识C++类的6个默认成员函数

目录 一、初始化和清理 二、拷贝复制 三、取地址重载 四、重要说明 五、注意事项 六、示例代码 在C中&#xff0c;当一个类没有显式定义某些成员函数时&#xff0c;编译器会自动生成6个默认成员函数。这些函数可以分为以下几类&#xff1a; 一、初始化和清理 1、构造函数…

Spring事务失效场景?

题目详细答案Spring事务失效的场景主要有以下几种。非public方法使用Transactional场景描述&#xff1a;Spring事务管理是基于AOP实现的&#xff0c;而AOP对于JDK动态代理或CGLib动态代理只会代理public方法。如果事务方法的访问修饰符为非public&#xff0c;SpringAOP无法正确…

1.电动汽车动力电池系统技术介绍与分类

1.电动汽车动力电池系统技术介绍与分类 1.1 电动汽车发展的三个 “黄金时代” 第一个黄金时代&#xff08;19 世纪末 - 20 世纪初&#xff09; 技术基础&#xff1a;铅酸蓄电池发明&#xff08;1859 年&#xff09;&#xff0c;推动电动三轮车&#xff08;1873 年&#xff09;、…

调用阿里云-阿里云百炼 AI

相关文档&#xff1a;大模型服务平台百炼控制台 多轮对话&#xff1a;通义千问模型的多轮对话_大模型服务平台百炼(Model Studio)-阿里云帮助中心 创建知识库&#xff1a;大模型服务平台百炼控制台 创建智能体&#xff1a;大模型服务平台百炼控制台 点击智能体发布后&#x…