URL.createObjectURL()
静态方法会创建一个 DOMString
,其中包含一个表示参数中给出的对象的URL。这个 URL 的生命周期和创建它的窗口中的 document
绑定。这个新的URL 对象表示指定的 File
对象或 Blob
对象。
语法
objectURL = URL.createObjectURL(object)
用法
// HTML
<input type="file" id="inp"> <img id="oImg" src=""/>
// js
document.getElementById("inp").onchange = function(event){
let file = this.files[0]
let url = URL.createObjectURL(file)
document.getElementById("oImg").setAttribute("src",url)
}
注意
在每次调用 createObjectURL()
方法时,都会创建一个新的 URL 对象,即使你已经用相同的对象作为参数创建过。当不再需要这些 URL 对象时,每个对象必须通过调用 URL.revokeObjectURL()
方法来释放。
浏览器在 document 卸载的时候,会自动释放它们,但是为了获得最佳性能和内存使用状况,你应该在安全的时机主动释放掉它们。