当前位置: 首页 > news >正文

dedecms修改网站教程兰州压热搜

dedecms修改网站教程,兰州压热搜,中国建设通网站,国外哪个网站专做展厅文章目录一、技术方案二、前端具体实现代码分析转换逻辑注意事项一、技术方案 后台返回 base64 数据 {code: 0,data: "base64;...", }前端进行数据格式转化并下载成 Excel 文件 这篇文章主要介绍第二个步骤的实现。 二、前端具体实现 代码 src/utils/transform…

文章目录

  • 一、技术方案
  • 二、前端具体实现
    • 代码
    • 分析
      • 转换逻辑
      • 注意事项

一、技术方案

  1. 后台返回 base64 数据
{code: 0,data: "base64;...",
}
  1. 前端进行数据格式转化并下载成 Excel 文件

这篇文章主要介绍第二个步骤的实现。

二、前端具体实现

代码

src/utils/transformat.ts

export function base64ToBlob(base64: string, mimeType) {const byteCharacters = atob(base64)const byteNumbers = new Array(byteCharacters.length)for (let i = 0; i < byteCharacters.length; i++) {byteNumbers[i] = byteCharacters.charCodeAt(i)}const byteArray = new Uint8Array(byteNumbers)return new Blob([byteArray], { type: mimeType })
}

src/pages/test.tsx

 const handleDownload = (file: Blob) => {const fileName = `test_${Date.now()}.xlsx`const element = document.createElement("a")element.href = URL.createObjectURL(file)element.download = fileNamedocument.body.appendChild(element)element.click()document.body.removeChild(element)}
const onClick = () => {getFileContent(id).then((res) => {if (res.code === 0) {const blob = base64ToBlob(res.data,"application/vnd.openxmlformats-officedocument.spreadsheetml.sheet")handleDownload(blob)} else {console.error('download failed...')}})
}

分析

转换逻辑

React 本身并没有提供直接的 base64 → Blob → 下载 的 API,因为这是浏览器原生能力。但是浏览器里有几个通用 API 可以用来处理:

  1. atob / btoa

    • atob(base64):把 base64 字符串解码为普通字符串(二进制仍然是字符串形式)。
    • btoa(string):把字符串编码为 base64。
    • ⚠️ 注意:只能处理 非 UTF-8 的 ASCII 字符,遇到中文等多字节字符会报错。
  2. Blob

    • 接着可以把 Uint8ArrayArrayBuffer 转成 Blob

    • 下载文件时常用:

      const blob = new Blob([uint8Array], { type: "application/vnd.openxmlformats-officedocument.spreadsheetml.sheet" });
      
  3. URL.createObjectURL

    • 最后把 Blob 转成一个临时的 URL,用于 <a> 下载。

      const url = URL.createObjectURL(blob);
      

注意事项

  • MIME 类型要正确,Excel 用:application/vnd.openxmlformats-officedocument.spreadsheetml.sheet
  • PDF 用:application/pdf
  • base64 一般比较大,建议后端尽量返回二进制(Blob 流),效率更高。
  • 如果后端要传 base64,最好用 gzip 压缩后再传,否则网络传输会膨胀 30% 左右。
http://www.dtcms.com/a/534942.html

相关文章:

  • 网站建设概述江苏有什么网站找工程建设人员
  • 广州大型网站建设公司排名项目网络计划图
  • 网站为什么网页打不开怎么办宁波专业建网站外包
  • 成都网站建设推广好王烨是哪个小说的主角
  • 东莞市网站开发福田商城网站制作
  • 做网站竞价是什么意思新手怎样在手机上做电商
  • 用dw做红米网站十大设计创意网站
  • 做网站需要交印花税推广神器
  • 网站建设页面做设计需要知道的几个网站
  • 二手商品网站制作上海热点事件
  • 广州站西手表网站建设面临的困难
  • 做网站做小程序推广网站分哪些种类
  • 手机网站首页源码屋
  • 淘宝网站经营与建设论文建设部网站举报
  • 项目网站分析wordpress数据表前缀
  • 企维多类似网站建筑方案设计
  • 成品网站源码1688的优势济南互联网网站建设价格
  • 网站开发w亿玛酷1订制个人网站多少钱一年
  • 青田网站做服装找工作最强的网站建设电话
  • 网站开发哪种语言最好用户体验度好的网站
  • 安装Wordpress个人网站化妆品购物网站排名
  • vs2010网站开发与发布全球搜索引擎排名
  • 烟台网站建设给力臻动传媒管庄地区网站建设
  • 网站优化的监测评估网站怎么做动效
  • 视频网站做视频节目赚钱吗网站按钮确定后图片怎么做
  • 成都专做婚介网站的公司水泥公司网站建设
  • 凡科建站登录入口有哪些免费的视频网站
  • 广东省城乡建设部网站首页菠菜网站如何做推广
  • 暗网网站有那些建设银行官方网站网址
  • 网站定制价格打代码做网站的软件