html5 Загрузка изображения - PullRequest
9 голосов
/ 17 января 2012

Я пытаюсь сделать ОЧЕНЬ простой загрузчик изображений в html5.

<input type="file" multiple=""/>

Все, что я хотел бы сделать, это показать, что загружено, без использования PhP или чего-либо еще. Могу ли я использовать код, подобный этому?

<img src="WHATEVER WAS UPLOADED"/>

Спасибо!

Ответы [ 2 ]

5 голосов
/ 14 декабря 2012

я нашел

http://www.html5rocks.com/en/tutorials/file/dndfiles/

довольно полезно.

если вы не хотите передавать изображение на какой-либо сервер (я предполагаю, что это из вашего вопроса), вы можете просто обновить изображение локально:

<style>
  .thumb {
    height: 75px;
    border: 1px solid #000;
    margin: 10px 5px 0 0;
    }
 </style>

<input type="file" id="files" name="files[]" multiple />
<output id="list"></output>

<script>
  function handleFileSelect(evt) {
    var files = evt.target.files; // FileList object

   // Loop through the FileList and render image files as thumbnails.
   for (var i = 0, f; f = files[i]; i++) {

     // Only process image files.
     if (!f.type.match('image.*')) {
       continue;
     }

     var reader = new FileReader();

     // Closure to capture the file information.
     reader.onload = (function(theFile) {
       return function(e) {
          // Render thumbnail.
          var span = document.createElement('span');
          span.innerHTML = ['<img class="thumb" src="', e.target.result,
                        '" title="', escape(theFile.name), '"/>'].join('');
          document.getElementById('list').insertBefore(span, null);
    };
      })(f);

      // Read in the image file as a data URL.
      reader.readAsDataURL(f);
    }
  }

  document.getElementById('files').addEventListener('change', handleFileSelect, false);

 </script>

или что-то подобное.

0 голосов
/ 18 января 2012

Вы можете заархивировать это с помощью HTML5 File Api.

Следующее руководство поможет вам начать: Чтение локальных файлов в JavaScript

...