Skip to content

LimeFileUtils 文件工具组件

fileUtils 是一款可以轻松地在文件和 Base64 编码的数据之间进行转换的UTS API工具包,提供了文件与Base64、DataURL之间的相互转换功能,大大提高开发效率。适用于需要处理图片预览、文件上传、数据传输等场景。

插件依赖:无特殊依赖

文档链接

📚 组件详细文档请访问以下站点:

安装方法

  1. 在uni-app插件市场入口 中搜索并导入lime-file-utils
  2. 导入后可能需要重新编译项目
  3. 在页面中通过import引入相关API

代码演示

基础用法

  • APP是同步函数,非APP是Promise
js
import { fileToDataURL, dataURLToFile, processFile, ProcessFileOptions  } from '@/uni_modules/lime-file-utils'
const url = ref('')
const src = ref('')
const base64 = ``

// #ifdef WEB || MP
fileToDataURL('/static/logo.png').then(res => {
	url.value = res
})
dataURLToFile(base64).then(res => {
	src.value = res
})
// #endif
// #ifdef APP
url.value = fileToDataURL('/static/logo.png') ?? ''
src.value = dataURLToFile(base64) ?? '';
// #endif

// 相当于 fileToDataURL
processFile({
	type: 'toDataURL',
	path: '/static/logo.png',
	success: (res: string)=>{
		url.value = res
	}
} as ProcessFileOptions)

// 相当于 dataURLToFile
processFile({
	type: 'toFile',
	path: base64,
	success: (res: string)=>{
		src.value = res
	}
} as ProcessFileOptions)

fileToDataURL

文件图片转成 URL(data URL),接收一个文件路径,APP 返回的是DataURLnull, 非APP 返回的是Promise<string>

js
fileToDataURL(filePath : string)

fileToBase64

文件图片转成 Base64, 接收一个文件路径,APP 返回的是Base64null, 非APP 返回的是Promise<string>

js
fileToBase64(filePath : string)

dataURLToFile

Base64 编码的数据 URL(data URL)保存为临时路径,接收一个dataURL,参数filename为可选, APP返回的是stringnull,非APP 返回的是Promise<string>

js
dataURLToFile(dataURL : string, filename : NullableString = null)

processFile

是上面三个函数的总和,接收ProcessFileOptions

js
processFile({
	type: 'toBase64' | 'toDataURL' | 'toFile',
	path: string,
	filename?: string,//如果是toFile,则可以设置保存文件的文件名
	success ?: (res : string) {},
	fail ?: (res : any) {},
	complete ?: (res : any) {}
} as ProcessFileOptions)

API文档

主要函数

函数名说明参数返回值
fileToDataURL将文件或图片转成DataURLfilePath: stringAPP: string | null
非APP: Promise<string>
fileToBase64将文件或图片转成Base64filePath: stringAPP: string | null
非APP: Promise<string>
dataURLToFile将DataURL保存为临时文件dataURL: string, filename?: stringAPP: string | null
非APP: Promise<string>
processFile综合处理函数options: ProcessFileOptionsvoid

ProcessFileOptions 参数说明

属性名说明类型默认值
type处理类型'toDataURL' | 'toBase64' | 'toFile'-
path文件路径或DataURLstring-
filename保存文件名(仅toFile类型可用)string-
success成功回调函数(res: string) => void-
fail失败回调函数(res: any) => void-
complete完成回调函数(res: any) => void-

使用注意事项

  1. APP平台下函数是同步的,返回结果直接使用
  2. 非APP平台(如H5、小程序)下函数是异步的,返回Promise
  3. 在条件编译中需要注意区分平台差异
  4. dataURLToFile函数的filename参数是可选的,如不提供会自动生成临时文件名
  5. 处理大文件时可能会占用较多内存,请注意性能影响

平台差异说明

函数APPH5微信小程序其他小程序
fileToDataURL同步异步异步异步
fileToBase64同步异步异步异步
dataURLToFile同步异步异步异步
processFile支持支持支持支持

支持与赞赏

如果你觉得本插件解决了你的问题,可以考虑支持作者:

支付宝赞助微信赞助

源代码

组件源码