jquery - 提供多个 Base64 图像下载

标签 jquery django listview

我的 django 应用程序有一个带有 base64 编码图像的模型。

我想向我的 ListView 添加选项,以将所有显示的图像下载到用户选择的位置。

我应该创建一个 AJAX View ,还是 jQuery 可以处理它?<​​/p>

我在谷歌上搜索了一下,看到了一些提供单个文件下载的示例。但如何同时提供所有图像?

最佳答案

您可以在带有图像的页面上插入此脚本:

function download(data, file_name) {
  const a = document.createElement("a")
  a.href = data
  const extension = data.match(/^data:(.*?)\/(.*?);/)[2]
  a.setAttribute("download", file_name + "." + extension)
  a.style.display = "none"
  a.addEventListener("click", e => e.stopPropagation()) // not relevant for modern browsers
  document.body.appendChild(a)
  setTimeout(() => { // setTimeout - not relevant for modern browsers
    a.click()
    document.body.removeChild(a) 
  }, 0)
}
function download_all() {
  [...document.getElementsByClassName("dl")]
    .forEach((img, i) => download(img.src, "img" + i))
}
document
  .getElementById("dl_all")
  .addEventListener("click", download_all)
<button id="dl_all">download all</button>
<img class="dl" src="">
<img class="dl" src="">

这并不理想:例如,Chrome 会警告用户多次下载,FF 将显示多个保存对话框,除非用户将“应用程序”部分中的设置更改为“保存存档”。但我怀疑它是否可以修复。

当我运行此代码片段时,我的 Chrome 会阻止多次下载,但它在这里工作正常 https://jsfiddle.net/w7nqvjgd/以及我尝试过的其他环境。

更新: 或者(感谢 Steven 的想法)如果您对现代浏览器中多次下载的用户体验不满意,您可以在客户端上创建一个 zip 文件。请参阅https://github.com/Stuk/jszip

function download(data) {
  const a = document.createElement("a")
  a.href = "data:application/zip;base64," + data
  a.setAttribute("download", "imgs.zip")
  a.style.display = "none"
  a.addEventListener("click", e => e.stopPropagation()) // not relevant for modern browsers
  document.body.appendChild(a)
  setTimeout(() => { // setTimeout - not relevant for modern browsers
    a.click()
    document.body.removeChild(a) 
  }, 0)
}
function download_all() {
  var zip = new JSZip();
  [...document.getElementsByClassName("dl")]
    .forEach((img, i) => zip.file("img" + i, img.src.replace(/data:.*?;base64,/, ""), {base64: true}))
  zip.generateAsync({type: "base64"}).then(download)
}
document
  .getElementById("dl_all")
  .addEventListener("click", download_all)

// and an old school version
// for browsers incompatible with `download` attribute
function download_all_oldschool() {
  var zip = new JSZip();
  [...document.getElementsByClassName("dl")]
    .forEach((img, i) => zip.file("img" + i, img.src.replace(/data:.*?;base64,/, ""), {base64: true}))
  zip.generateAsync({type: "base64"}).then(data => window.location.href = "data:application/zip;base64," + data
)
}
document
  .getElementById("dl_all_oldschool")
  .addEventListener("click", download_all_oldschool)
<script src="https://cdn.jsdelivr.net/npm/jszip@3.3.0/dist/jszip.min.js"></script>
<button id="dl_all">download all</button>
<button id="dl_all_oldschool">download all (old school)</button>
<img class="dl" src="">
<img class="dl" src="">

关于jquery - 提供多个 Base64 图像下载,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/61035387/

相关文章:

javascript - Ajax 返回整页

javascript - 如何使用javascript在不刷新浏览器的情况下显示2个不同的按钮

javascript - 仅对背景位置 X 轴进行动画处理

python - Django/Python 静态文件未加载

c# - 如何修复 xamarin.forms 移动应用程序页面中的空 ListView

javascript - Knockout.js - 在通过可观察对象设置值时防止更改事件绑定(bind)触发

python - 从 Django 查询集中删除一些 "duplicates"

python - DRF 上没有正文的 POST

java - 在屏幕上显示 ListView 并通过单击按钮向其添加元素

android - ListView 项目在 android 中重复