- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我有一个 UI,用户可以在其中加载各种文件,其中包括图像。这些图像与预览缩略图很像这个例子:
https://developer.mozilla.org/en-US/docs/Web/API/File/Using_files_from_web_applications
要点:
<input type="file" onchange="handleFiles(this.files)">
JavaScript:
function handleFiles(e) {
…
const img = document.createElement("img");
img.src = window.URL.createObjectURL(file);
img.height = 60;
img.onload = function() {
window.URL.revokeObjectURL(this.src);
}
li.appendChild(img);
…
}
我的问题是关于 revokeObjectURL
的。据说
Set up the image's load event handler to release the object URL since it's no longer needed once the image has been loaded. This is done by calling the
window.URL.revokeObjectURL()
method and passing in the object URL string as specified byimg.src
.
但是,如果这样做,就不能在第二张图片上直接引用 src
。如:
other_image.src = thumbnail.src;
可以不撤销吗?仅在我动态删除缩略图时才撤销它?
或者;有没有其他更好的方法来引用图像?
const
no_files = document.getElementById("no_files"),
thumbs = document.getElementById("thumbs"),
preview = document.getElementById("preview")
;
function handle_files(files)
{
if (!files.length) {
no_files.classList.remove('hide');
} else {
no_files.classList.add('hide');
for (let i = 0; i < files.length; i++) {
const li = document.createElement("li");
thumbs.appendChild(li);
const img = document.createElement("img");
img.src = window.URL.createObjectURL(files[i]);
/*
* Commented out to alow ref of src
*
img.onload = function() {
window.URL.revokeObjectURL(this.src);
}
*/
li.appendChild(img);
}
}
}
function do_preview (e) {
if (e.target.tagName == 'IMG')
preview.src = e.target.src;
}
thumbs.addEventListener('mouseenter', do_preview, true);
html, body {
height: 100%;
}
* {
margin: 0;
padding: 0;
}
.hide {
display: none;
}
ul {
list-style: none;
}
li img {
max-width: 40px;
margin: 5px;
border: 1px solid #987;
}
.images {
display: flex;
padding: 10px;
overflow: auto;
height: 90%;
}
#preview {
max-width: 300px;
margin: 5px;
}
.list, .display {
border: 1px solid #789;
padding: 5px;
height: 90%;
}
.list {
flex: 0 0 auto;
overflow-y: scroll;
}
.display {
flex: 1;
}
<input type="file" multiple accept="image/*" onchange="handle_files(this.files)">
<div class="images">
<div class="list">
<p id="no_files">No files selected!</p>
<ul id="thumbs"></ul>
</div>
<div class="display">
<img id="preview">
</div>
</div>
最佳答案
由于这些 blob URL 指向来自用户磁盘的文件,因此最好不要撤销它。它们只是指向磁盘的直接指针,它们(几乎)不在内存中保存任何内容。
如果它们指向内存中的某个文件(例如使用 Blob 构造函数获取或生成),那么在您不再需要它们时立即撤销它们可能很重要,这样它们指向的 Blob 就可以可以释放收集的垃圾和分配给它们的内存。但是,如果您保留对指向的 Blob 的引用,或者如果您以后需要它们,那么不撤销它也是完全可以的,只要您确定不会创建太多这样的对象。
关于javascript - 引用已撤销的对象 URL,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/56711921/
假设我拥有域 mydomain.com,并且我在服务器上有一个 Web 应用程序,网址为 http://99.99.99.99:1234/MyApplication/startpage.somethi
我正在尝试通过以下方式更新已解析的 URL: u, _ := url.Parse(s) if u.Scheme == "" { u.Scheme = "https" } if u.Path =
如何将 www.somesite.com/api(.*) 映射到 www.somesite.com/$1:9000? (我需要将/api 映射到运行 @ 端口 9000 的 Play 框架应用程序)
我有一个资源结构,如航类 > 座位 > 预订,所以预订属于某个航类的某个座位: http://example.com/jdf_3prGPS4/1/jMBDy46PbNc
我想知道以下网址是否有效。 路径中的点,在主机之后: http://www.example.com/v.b.w..com 主机中的点,作为子域的一部分: http://v.b.w..co.manufa
我有两个域 - crmpicco.co.uk 和 ayrshireminis.com - 如果我浏览到: www.crmpicco.co.uk/mini/new我希望能够重定向到 www.ayrshi
我正在尝试使用 URL 重写和应用程序请求路由来重写到外部 URL。我设置了以下规则: 在规则中,“patternToMatch”是我试
我已经安装了带有 SharePoint 和 Url Rewrite 模块的 IIS 7.0。 是以下句子还是我配置错误才能看到这个结果? Url Redirect 可以将 url 重定向到任何内部(在
我想知道,为了获得良好的 SEO,您必须在 URL 中使用自然语言。您知道字符中单词或短语的最大大小吗?例如: www.me.com/this-is-a-really-long-url.htm 我问这
有人知道在 SEO 友好 URL 中使用逗号有什么问题吗?我正在使用一些在其 SEO 友好 URL 中使用大量逗号的软件;但我 100% 肯定我见过一些程序/平台无法正确识别 URL 并在第一个逗号后
我有一个网站,我正在为所有链接使用干净的 URL。我想知道对于简短的基本 URL 与较长的描述性 URL 有何看法。 例如,如果我的网站是关于 Georgia Bulldog 足球新闻的,那么哪个网站
我正在编写一个类似于 tinyurl 的 URL 缩短器,我想知道如何跟踪已经使用我的服务缩短的 URL?例如,tinyurl 为相同的长 URL 生成相同的小 URL,而不管是谁创建的。如
我是 magento 的新手。我正在开发一个模块。为此,我有一些要显示链接的 css 和 js 文件。我目前有类似 的链接 getSkinUrl('module_tryouts/css/jquery.
我想基于 HTTP_URL 重写 URL 以重定向到不同的端口,同时保留其余的 URL 和查询字符串(如果指定)。例如, http://host/john/page.aspx 应该重定向到 http:
我遇到了以下问题: 我的 Grails (2.2.0) 应用程序具有以下 URL 映射: "/api/clientQuote/$labcode/$cliCode/$quoCode"(controlle
我有一个很长的 URL,它不适合 URL 字段。它一直在修剪。该怎么办?有没有办法增加 SharePoint 2010 中的 URL 字段字符限制? 或者解决方法来容纳长 URL。例如,以下 URL
关闭。这个问题是off-topic .它目前不接受答案。 想改进这个问题? Update the question所以它是on-topic对于堆栈溢出。 9年前关闭。 Improve this que
我们从客户以前的开发人员那里继承了相当多的 Google Apps 脚本项目。 Apps 脚本通过嵌入式小部件部署在 Google 网站 (sites.google.com) 的各个页面上。每当我们需
我正在编写一些文档,但遇到了一些词汇问题: http://www.example.com/en/public/img/logo.gif 被称为“绝对”网址,对吗? ../../public/img/l
我们从客户以前的开发人员那里继承了相当多的 Google Apps 脚本项目。 Apps 脚本通过嵌入式小部件部署在 Google 网站 (sites.google.com) 的各个页面上。每当我们需
我是一名优秀的程序员,十分优秀!