react项目实现文件预览,比如PDF、txt、word、Excel、ppt等常见文件(腾讯云cos)

使用腾讯云文档预览,需要开通文档预览功能,该功能需要收费的。

使用限制

如果需要图片预览、视频或音频可以使用获取下载链接。

页面代码

cpp 复制代码
	<button 
		onClick=() => {
		handleClick('myself/文档.xlsx')
		}>
	预览</button>
      <div style={{ height: 400, width: 700 }}>
        <iframe height={400} width={700}
          src={preurl}
        >
        </iframe>
      </div>
cpp 复制代码
const [preurl,setPreurl] = useState('')

const handleClick = (key) => {
	getPreUrl(key).then((res) => {
	setPreurl(res);
})

}

使用cos获取预览文档链接

cpp 复制代码
let COS = require('cos-js-sdk-v5');

const COS_DATA = {
  Bucket: '', /* 存储桶,必须 */
  Region: 'ap-shanghai', /* 存储桶所在地域,必须字段 */
  SecretId: '',
  SecretKey: '',
}


// SECRETID 和 SECRETKEY 请登录 https://console.cloud.tencent.com/cam/capi 进行查看和管理
let cos = new COS({
  SecretId: COS_DATA.SecretId,
  SecretKey: COS_DATA.SecretKey,
});


export const getPreUrl = (key) => new Promise((resolve, reject) => {
  cos.getObjectUrl(
    {
      Bucket: COS_DATA.Bucket, // 填入您自己的存储桶,必须字段
      Region: COS_DATA.Region, // 存储桶所在地域,例如 ap-beijing,必须字段
      Key: key, // 存储在桶里的对象键(例如1.jpg,a/b/test.txt),支持中文,必须字段
      Sign: true, // 获取带签名的对象 URL
      Query: {
        'ci-process': 'doc-preview', /* 必须,数据万象处理能力,文档预览固定为 doc-preview */
        dstType: 'html',
      }
    },
    function (err, data) {
      if (err) { 
        reject(err);
      }
      resolve(data.Url);
    }
  );
});

更详细内容查看https://cloud.tencent.com/document/product/460/47495

相关推荐
云水一下2 小时前
TypeScript 从零基础到精通(五):高级类型与泛型
前端·javascript·typescript
云水一下3 小时前
TypeScript 从零基础到精通(六):类型声明与模块化
javascript·typescript
微扬嘴角3 小时前
React篇1--JSX语法规则、组件、组件实例的3大特性
前端·react.js·前端框架
xiaofeichaichai4 小时前
Map / Set / WeakMap / WeakSet
前端·javascript
有梦想的程序星空6 小时前
【环境配置】Vue3项目离线化本地部署echarts全攻略
前端·javascript·vue·echarts
薛先生_0996 小时前
vue-路由重定向
前端·javascript·vue.js
橘子星7 小时前
基于 ES6 语法的 NLP 任务模块化开发实践
前端·javascript
月光刺眼7 小时前
JS 底层执行机制探讨:执行上下文、变量提升与调用栈
前端·javascript
ZC跨境爬虫7 小时前
跟着 MDN 学 JavaScript day_1:什么是 JavaScript?
开发语言·前端·javascript·ecmascript
xiaofeichaichai8 小时前
Vue 响应式原理
前端·javascript·vue.js