uni-app iOS H5上的image标签无法正常展示base64图片
uni-app iOS H5上的image标签无法正常展示base64图片
操作步骤:
ios在safari上打开vue界面,对应image标签未显示图片。
预期结果:
ios在safari上打开vue界面,对应image标签和Android上表现一样,可以显示图片。
实际结果:
ios在safari上打开vue界面,对应image标签不展示base64的图片。
bug描述:
使用image标签加载图片,给src属性设置图片的base64编码,在Android,google浏览器上均可以显示图片,在ios上图片不显示。 备注:base64字符串前缀data:image/png;base64,去掉和不去掉,ios都无法展示该图片。
base64如下:

项目信息 | 描述 |
---|---|
产品分类 | HTML5+ |
HBuilderX版本号 | 3.0.7 |
手机系统 | iOS |
手机系统版本号 | iOS 12.4 |
手机厂商 | 苹果 |
手机机型 | iphone 6 plus |
打包方式 | 云端 |
更多关于uni-app iOS H5上的image标签无法正常展示base64图片的实战教程也可以访问 https://www.itying.com/category-93-b0.html
HX基座跑的img标签是可以显示base64的图片,看你的描述是Safari上不能显示是吗?为啥要跑在safari上? 是怎么在safari上打开的vue界面的?
更多关于uni-app iOS H5上的image标签无法正常展示base64图片的实战教程也可以访问 https://www.itying.com/category-93-b0.html
这是一个iOS Safari浏览器对base64图片格式的兼容性问题。建议尝试以下解决方案:
-
确保base64字符串格式正确,保留
data:image/png;base64,
前缀 -
检查图片大小是否超过iOS Safari的限制(建议控制在2MB以内)
-
尝试使用以下格式转换base64字符串:
// 移除可能存在的换行符和空格
const cleanBase64 = base64Str.replace(/\s/g,'');
- 如果问题仍然存在,可以尝试将base64转为Blob对象后使用URL.createObjectURL()来显示:
function base64ToBlob(base64) {
const parts = base64.split(';base64,');
const contentType = parts[0].split(':')[1];
const raw = window.atob(parts[1]);
const uInt8Array = new Uint8Array(raw.length);
for (let i = 0; i < raw.length; ++i) {
uInt8Array[i] = raw.charCodeAt(i);
}
return new Blob([uInt8Array], {type: contentType});
}
const blob = base64ToBlob(base64Str);
const imgUrl = URL.createObjectURL(blob);