goview_vue/src/utils/file.ts

55 lines
1.5 KiB
TypeScript
Raw Normal View History

/**
* *
* @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('文件读取失败!')
}
})
}
2022-04-05 19:01:52 +08:00
/**
* * a
* @param url
* @param filename
* @param fileSuffix
*/
2022-04-07 19:54:17 +08:00
export const downloadByA = (url: string, filename = new Date().getTime(), fileSuffix?: string) => {
2022-04-05 19:01:52 +08:00
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
*/
2022-04-05 19:01:52 +08:00
export const downloadTextFile = (
content: string,
2022-04-07 19:54:17 +08:00
filename = new Date().getTime(),
fileSuffix?: string
) => {
// 字符内容转变成blob地址
const blob = new Blob([content])
2022-04-05 19:01:52 +08:00
downloadByA(URL.createObjectURL(blob), filename, fileSuffix)
}