file.ts

/** * *获取上传的文件数据 * @param { File } file 文件对象 */ export const readFile = (file: File) => { return new Promise((resolve: Function) => { try { const reader = new FileReader() reader.onload = (evt: ProgressEvent<FileReader>) => { if (evt.target) { resolve(evt.target.result) } } reader.readAsText(file) } catch (error) { window['$message'].error('文件读取失败!') } }) } /** * * 通过 a 标签下载数据 * @param url * @param filename * @param fileSuffix */ export const downloadByA = (url: string, filename = new Date().getTime(), fileSuffix?: string) => { const ele = document.createElement('a') // 创建下载链接 ele.download = `${filename}.${fileSuffix}` //设置下载的名称 ele.style.display = 'none' // 隐藏的可下载链接 // 字符内容转变成blob地址 ele.href = url // 绑定点击时间 document.body.appendChild(ele) ele.click() // 然后移除 document.body.removeChild(ele) } /** * * 下载数据 * @param { string } content 数据内容 * @param { ?string } filename 文件名称(默认随机字符) * @param { ?string } fileSuffix 文件名称(默认随机字符) */ export const downloadTextFile = ( content: string, filename = new Date().getTime(), fileSuffix?: string ) => { // 字符内容转变成blob地址 const blob = new Blob([content]) downloadByA(URL.createObjectURL(blob), filename, fileSuffix) }

__EOF__

本文作者龙陌
本文链接https://www.cnblogs.com/longmo666/p/18568078.html
关于博主:评论和私信会在第一时间回复。或者直接私信我。
版权声明:本博客所有文章除特别声明外,均采用 BY-NC-SA 许可协议。转载请注明出处!
声援博主:如果您觉得文章对您有帮助,可以点击文章右下角推荐一下。您的鼓励是博主的最大动力!
posted @   龙陌  阅读(9)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· 震惊!C++程序真的从main开始吗?99%的程序员都答错了
· 【硬核科普】Trae如何「偷看」你的代码?零基础破解AI编程运行原理
· 单元测试从入门到精通
· 上周热点回顾(3.3-3.9)
· winform 绘制太阳,地球,月球 运作规律
点击右上角即可分享
微信分享提示