踩了一个巨坑。html
目前微信ios/android 均能长按保存src=base64的图片 (微信android x5 专门解决了这个问题);android
可是android其余App没有针对解决这个系统问题(姑且认为是问题吧),因此长按base64图片 没法出现保存选项,而是出现了默认的"选择、复制、粘贴 ";ios
尝试使用blob也不行;微信
因此目前能解决的办法只有经过后台绕一圈;dom
base64 --> 后台 ---> url url
blob 转 base64spa
function blobToDataURL(blob, callback) { var a = new FileReader(); a.onload = function (e) { callback(e.target.result); } a.readAsDataURL(blob); }
base64图片 转 blobcode
function dataURLtoBlob(dataurl) { var arr = dataurl.split(','), mime = arr[0].match(/:(.*?);/)[1], bstr = atob(arr[1]), n = bstr.length, u8arr = new Uint8Array(n); while(n--){ u8arr[n] = bstr.charCodeAt(n); } return new Blob([u8arr], {type:mime}); }
blob 插入html domhtm
$("#img").attr("src",window.URL.createObjectURL(blob));