当前位置: 代码网 > it编程>编程语言>Javascript > 关于JavaScript的URL.createObjectURL()的使用方法

关于JavaScript的URL.createObjectURL()的使用方法

2024年05月15日 Javascript 我要评论
url.createobjecturl() 静态方法会创建一个 domstring,其中包含一个表示参数中给出的对象的url。这个 url 的生命周期和创建它的窗口中的 document 绑定。这个新

url.createobjecturl() 静态方法会创建一个 domstring,其中包含一个表示参数中给出的对象的url。这个 url 的生命周期和创建它的窗口中的 document 绑定。这个新的url 对象表示指定的 file 对象或 blob 对象。

url.createobjecturl(blob)和filereader.readasdataurl(file)很相似,下面是个人的一些理解,如有不正确的地方,欢迎指出:

主要区别

  • 通过filereader.readasdataurl(file)可以获取一段data:base64的字符串
  • 通过url.createobjecturl(blob)可以获取当前文件的一个内存url

执行时机:

  • createobjecturl是同步执行(立即的)
  • filereader.readasdataurl是异步执行(过一段时间)

内存使用:

  • createobjecturl返回一段带hash的url,并且一直存储在内存中,直到document触发了unload事件(例如:document close)或者执行revokeobjecturl来释放。
  • filereader.readasdataurl则返回包含很多字符的base64,并会比blob url消耗更多内存,但是在不用的时候会自动从内存中清除(通过垃圾回收机制)

兼容性方面两个属性都兼容ie10以上的浏览器。

优劣对比:

  • 使用createobjecturl可以节省性能并更快速,只不过需要在不使用的情况下手动释放内存
  • 如果不太在意设备性能问题,并想获取图片的base64,则推荐使用filereader.readasdataurl

使用方式:

objecturl = url.createobjecturl(blob);

示例

html 文件

<input type="file" id="btn" accept="image/*" value="点击上传" />
<img id="img"/>

js 文件

btn.addeventlistener('change',function(){
	let file = this.files[0];
	// 进一步防止文件类型错误
	if(!/image\/\w+/.test(file.type)){  
        alert("看清楚,这个需要图片!");  
        return false;  
    }  
	img.src = url.createobjecturl(file)
})

到此这篇关于关于url.createobjecturl()的使用方法的文章就介绍到这了,更多相关url.createobjecturl()用法内容请搜索代码网以前的文章或继续浏览下面的相关文章希望大家以后多多支持代码网!

(0)

相关文章:

版权声明:本文内容由互联网用户贡献,该文观点仅代表作者本人。本站仅提供信息存储服务,不拥有所有权,不承担相关法律责任。 如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 2386932994@qq.com 举报,一经查实将立刻删除。

发表评论

验证码:
Copyright © 2017-2025  代码网 保留所有权利. 粤ICP备2024248653号
站长QQ:2386932994 | 联系邮箱:2386932994@qq.com