JS отображение фотографий независимо от того, что расширение - PullRequest
0 голосов
/ 12 февраля 2020

Моя JS проблема довольно проста: у меня есть фрагмент кода, который читает и отображает фотографии из данной папки P C. Проблема в том, что я не знаю, как заставить его отображать все типы фотографий, не принимая во внимание, какое расширение они имеют. В настоящее время отображаются только файлы .jpg.

Вот как я написал:

var index = 1;
var tempImg = new Image();
tempImg.onload = function(){
    appendImg();
}
var loadImg = function(index){
    tempImg.src = 'img/' + index + '.jpg';
}
var appendImg = function(){
    var img = document.createElement('img');
    img.src = tempImg.src;

    document.body.appendChild(img);
    loadImg(index++);

}
loadImg(index);

Ответы [ 2 ]

1 голос
/ 12 февраля 2020

Если вы делаете это локально, вы можете использовать файловую систему api

https://www.html5rocks.com/en/tutorials/file/filesystem/

Если нет, и у вас есть папка

0.jpg
1.gif
2.png
...

тогда, если вы знаете типы изображений, которые вы можете встретить, вы можете попробовать каждый

<style>
img { width:50px }
</style>
<script>
const folder = "img/"; 
const maxImages = 4; // I think there are at least 4 images in the folder
const suffix = ["jpg","gif","png"]; 
let cnt = 0, idx = 0, container, img;
const loadImage = () => {
  if (idx >= maxImages) return; 
  if (cnt ===0) img = new Image();
  img.onload=function() {
    var saveImg = document.createElement("img");
    saveImg.src = this.src;
    saveImg.title = folder+idx+"."+suffix[cnt];
    container.appendChild(saveImg);
    idx++;
    cnt=0; 
    console.log("new image");
    loadImage()
  }
  img.onerror = function() {
    console.log("failed to load",folder+idx+"."+suffix[cnt]);
    cnt++; // try next suffix
    if (cnt >= suffix.length) {
      console.log("gave up")
      var saveImg = document.createElement("img");
      saveImg.title = folder+idx+" not found";
      saveImg.src = '';
      container.appendChild(saveImg);
      cnt=0; idx++;
    }
    loadImage();
  }
  console.log("trying to load", folder+idx+"."+suffix[cnt]);
  img.src = folder+idx+"."+suffix[cnt];
}

window.addEventListener("load",function() {
  container = document.getElementById("imagecontainer");
  loadImage();
});


</script>
<div id="imagecontainer"></div>
0 голосов
/ 12 февраля 2020

Я предполагаю, что ваши фотографии пронумерованы с 1 года. Это позволяет просто использовать увеличивающийся индексный номер, за которым следует жестко закодированное расширение файла, чтобы загрузить изображения, но, как вы поняли, произойдет сбой, если расширение не .jpg.

Что вы можете сделать, это сохранить точное имя файла, включая расширение внутри массива и использовать индексный номер для ссылки на конкретную картинку внутри.

var index = 0;
var myPictures = ["1.jpg", "2.png", "3.png"];
var tempImg = new Image();
tempImg.onload = function() {
  appendImg();
}
var loadImg = function() {
  tempImg.src = 'img/' + myPictures[index];
}
var appendImg = function() {
  var img = document.createElement('img');
  img.src = tempImg.src;

  document.body.appendChild(img);
  if (index + 1 < myPictures.length) {
    index++;
    loadImg();
  }


}
loadImg();
...