goview_vue/src/utils/file.ts

116 lines
2.9 KiB
TypeScript
Raw Normal View History

/**
* * base64转file
* @param dataurl
* @param fileName
* @returns
*/
export const base64toFile = (dataurl: string, fileName: string) => {
let dataArr = dataurl.split(","),
mime = (dataArr as any[])[0].match(/:(.*?);/)[1],
bstr = atob(dataArr[1]),
n = bstr.length,
u8arr = new Uint8Array(n);
while (n--) {
u8arr[n] = bstr.charCodeAt(n);
}
return new File([u8arr], fileName, { type: mime });
}
2022-05-27 20:09:48 +08:00
/**
* * file转url
*/
export const fileToUrl = (file: File): string => {
const Url = URL || window.URL || window.webkitURL
const ImageUrl = Url.createObjectURL(file)
return ImageUrl
}
/**
* * url转file
*/
2022-05-28 11:50:17 +08:00
export const urlToFile = (fileUrl: string, fileName = `${new Date().getTime()}`): File => {
2022-05-27 20:09:48 +08:00
const dataArr = fileUrl.split(',')
const mime = (dataArr as any[])[0].match(/:(.*);/)[1]
const originStr = atob(dataArr[1])
return new File([originStr], `${fileName}`, { type: mime })
2022-05-27 20:09:48 +08:00
}
/**
* * file转base64
* @param file
* @param callback
*/
export const fileTobase64 = (file: File, callback: Function) => {
let reader = new FileReader()
reader.readAsDataURL(file)
reader.onload = function (e: ProgressEvent<FileReader>) {
if (e.target) {
let base64 = e.target.result
callback(base64)
}
}
}
/**
* * canvas转file
* @param canvas
*/
2022-05-28 11:50:17 +08:00
export const canvastoFile = (canvas: HTMLCanvasElement, name?: string) => {
2022-05-27 20:09:48 +08:00
const dataurl = canvas.toDataURL('image/png')
2022-05-28 11:50:17 +08:00
return urlToFile(dataurl, name)
2022-05-27 20:09:48 +08:00
}
/**
* *
* @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)
}
/**
2022-05-27 20:09:48 +08:00
* *
* @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)
2022-05-27 20:09:48 +08:00
}