更新记录
0.1.2(2025-09-15) 下载此版本
- fix: 修复鸿蒙next 对音频无法转换的问题
0.1.1(2025-08-30) 下载此版本
- fix: 修复鸿蒙next不触发成功和失败回调
0.1.0(2025-08-24) 下载此版本
- feat: 兼容鸿蒙Next
平台兼容性
uni-app(4.66)
Vue2 | Vue3 | Chrome | Safari | app-vue | app-nvue | Android | iOS | 鸿蒙 |
---|---|---|---|---|---|---|---|---|
√ | √ | √ | √ | √ | - | 5.0 | √ | √ |
微信小程序 | 支付宝小程序 | 抖音小程序 | 百度小程序 | 快手小程序 | 京东小程序 | 鸿蒙元服务 | QQ小程序 | 飞书小程序 | 快应用-华为 | 快应用-联盟 |
---|---|---|---|---|---|---|---|---|---|---|
- | - | - | - | - | - | - | - | - | - | - |
uni-app x(4.76)
Chrome | Safari | Android | iOS | 鸿蒙 | 微信小程序 |
---|---|---|---|---|---|
√ | √ | 5.0 | √ | √ | - |
lime-file-utils 文件工具组件
fileUtils 是一款可以轻松地在文件和 Base64 编码的数据之间进行转换的UTS API工具包,提供了文件与Base64、DataURL之间的相互转换功能,大大提高开发效率。适用于需要处理图片预览、文件上传、数据传输等场景。
插件依赖:无特殊依赖
文档链接
📚 组件详细文档请访问以下站点:
安装方法
- 在uni-app插件市场中搜索并导入
lime-file-utils
- 导入后可能需要重新编译项目
- 在页面中通过import引入相关API
代码演示
基础用法
- APP是同步函数,非APP是Promise
import { fileToDataURL, dataURLToFile, processFile, ProcessFileOptions } from '@/uni_modules/lime-file-utils'
const url = ref('')
const src = ref('')
const base64 = `***41rGXzlhARmCBWQIFpAhWECGYAEZggVkCBaQIVhAhmABGYIFZAgWkDG2Jbw2gntxbd32aPMrOrgm2/wVffB9gi8O/oM4YQEZggVkCBaQIVhAhmABGYIFZAgWkCFYQIZgARmCBWQIFpAxtiXcdG1y9cGW12RTf9lrVzc+2rwq8drX+MgJC8gQLCBDsIAMwQIyBAvIECwgQ7CADMECMgQLyBAsIEOwgIzklnDTwavZrjl4ed/mew0OAK9t9w4Ocp2wgAzBAjIEC8gQLCBDsIAMwQIyBAvIECwgQ7CADMECMgQLyBjbEm7OoDZvlPvgodzmLXiPL/XySMuPfeq9lm3egfjICQvIECwgQ7CADMECMgQLyBAsIEOwgAzBAjIEC8gQLCBDsICMc/cSbs6Xrq3S/tx7pGvP8/h21y7Ue3weE8hfOWEBGYIFZAgWkCFYQIZgARmCBWQIFpAhWECGYAEZggVkCBaQIVhAxur4ubjtHJytTg2JN5e9g89zbW27+Qu59tn/3NuHP3LCAjIEC8gQLCBDsIAMwQIyBAvIECwgQ7CADMECMgQLyBAsIOMnOikaMbjw2twJbr7OoIOPdM3UP+O1X8hgZJywgAzBAjIEC8gQLCBDsIAMwQIyBAvIECwgQ7CADMECMgQLyFi9l/DFtTXZ8r2EU67tFh9fatMHbxs/+KM5YQEZggVkCBaQIVhAhmABGYIFZAgWkCFYQIZgARmCBWQIFpAxdi/htTHdi+i9hC+uvdejT/2FfPAi9YV7CYFvJFhAhmABGYIFZAgWkCFYQIZgARmCBWQIFpAhWECGYAEZY/cSbl6Fdm24N6i4ARwcyh0cr428V/QSwIMfzQkLyBAsIEOwgAzBAjIEC8gQLCBDsIAMwQIyBAvIECwgQ7CAjHP3El7bAD5OpQ7OEn+1+SebfalT7xV17c/xyAkLyBAsIEOwgAzBAjIEC8gQLCBDsIAMwQIyBAvIECwgQ7CAjLEtIb8qjtcOjvKuPdLyf1BxbGtLCHwjwQIyBAvIECwgQ7CADMECMgQLyBAsIEOwgAzBAjIEC8j4Z+qFikO5QS9rqWsjuBeDz7N5A+Y1B2+3LH6Nf5ywgBDBAjIEC8gQLCBDsIAMwQIyBAvIECwgQ7CADMECMgQLyBAsIGNs/PyieGnr4EZ06srJa68z6NojTf31D/7yDz7SCycsIEOwgAzBAjIEC8gQLCBDsIAMwQIyBAvIECwgQ7CADMECMla3hC8273c8OKea***ibo7zlW0I/dW84aHNt+mLwz+GEBWQIFpAhWECGYAEZggVkCBaQIVhAhmABGYIFZAgWkCFYQMa5LeEH+9SBW3SSufnYg+/15X9ZJywgQ7CADMECMgQLyBAsIEOwgAzBAjIEC8gQLCBDsIAMwQIybAn3bA7corfObT72tb3hn92d4Obdhe4lBL6RYAEZggVkCBaQIVhAhmABGYIFZAgWkCFYQIZgARmCBWSc2xIevAptytRHm1pvHRzKXZtSbg7uHl273XL5V+SEBWQIFpAhWECGYAEZggVkCBaQIVhAhmABGYIFZAgWkCFYQMbP5sDtg12bQG7eObj8p//yMd3mIx28udIJC8gQLCBDsIAMwQIyBAvIECwgQ7CADMECMgQLyBAsIEOwgIyxLSHAv80JC8gQLCBDsIAMwQIyBAvIECwgQ7CADMECMgQLyBAsIEOwgAzBAjIEC8gQLCBDsIAMwQIyBAvIECwgQ7CADMECMgQLyBAsIEOwgAzBAjL+DwEJMVCBletEAAAAAElFTkSuQmCC`
// #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 返回的是DataURL
或null
, 非APP 返回的是Promise<string>
fileToDataURL(filePath : string)
fileToBase64
将文件
或图片
转成 Base64
, 接收一个文件路径,APP 返回的是Base64
或null
, 非APP 返回的是Promise<string>
fileToBase64(filePath : string)
dataURLToFile
将 Base64
编码的数据 URL(data URL)
保存为临时路径,接收一个dataURL,参数filename
为可选, APP返回的是string
或null
,非APP 返回的是Promise<string>
dataURLToFile(dataURL : string, filename : NullableString = null)
processFile
是上面三个函数的总和,接收ProcessFileOptions
processFile({
type: 'toBase64' | 'toDataURL' | 'toFile',
path: string,
filename?: string,//如果是toFile,则可以设置保存文件的文件名
success ?: (res : string) {},
fail ?: (res : any) {},
complete ?: (res : any) {}
} as ProcessFileOptions)
API文档
主要函数
函数名 | 说明 | 参数 | 返回值 |
---|---|---|---|
fileToDataURL | 将文件或图片转成DataURL | filePath: string | APP: string | null 非APP: Promise\<string> |
fileToBase64 | 将文件或图片转成Base64 | filePath: string | APP: string | null 非APP: Promise\<string> |
dataURLToFile | 将DataURL保存为临时文件 | dataURL: string, filename?: string | APP: string | null 非APP: Promise\<string> |
processFile | 综合处理函数 | options: ProcessFileOptions | void |
ProcessFileOptions 参数说明
属性名 | 说明 | 类型 | 默认值 |
---|---|---|---|
type | 处理类型 | 'toDataURL' | 'toBase64' | 'toFile' | - |
path | 文件路径或DataURL | string | - |
filename | 保存文件名(仅toFile类型可用) | string | - |
success | 成功回调函数 | (res: string) => void | - |
fail | 失败回调函数 | (res: any) => void | - |
complete | 完成回调函数 | (res: any) => void | - |
使用注意事项
- APP平台下函数是同步的,返回结果直接使用
- 非APP平台(如H5、小程序)下函数是异步的,返回Promise
- 在条件编译中需要注意区分平台差异
- dataURLToFile函数的filename参数是可选的,如不提供会自动生成临时文件名
- 处理大文件时可能会占用较多内存,请注意性能影响
平台差异说明
函数 | APP | H5 | 微信小程序 | 其他小程序 |
---|---|---|---|---|
fileToDataURL | 同步 | 异步 | 异步 | 异步 |
fileToBase64 | 同步 | 异步 | 异步 | 异步 |
dataURLToFile | 同步 | 异步 | 异步 | 异步 |
processFile | 支持 | 支持 | 支持 | 支持 |
支持与赞赏
如果你觉得本插件解决了你的问题,可以考虑支持作者:
支付宝赞助 | 微信赞助 |
---|---|
![]() |
![]() |