2014-12-05 3 views
1

Как мы можем обеспечить соблюдение возвращать тип изображения (в случае если он не возвращается) при использовании readAsDataURL читать изображение,readAsDataURL не возвращает тип изображения

window.onload = function() { 
    if (window.File && window.FileList && window.FileReader) { 
     $("#file").on("change", function(event) { 
      event.preventDefault(); 
      var output = document.getElementById("result"); 
      existingNode = document.getElementById("addMore"); 
      var files = event.target.files; 
      for (var i = 0; i < files.length; i++) 
      { 
       var file = files[i]; 
      var picReader = new FileReader(); 
      picReader.onload = function(event) { 
       var picFile = event.target; 
       var formElement = document.getElementById("submitForm"); 
       var dataToBeSent = new FormData(formElement); 

       count++; 
       var div = document.createElement("div"); 
       div.innerHTML = '<div class="fl pu_mr1 pu_mr2 wrap' + count + '">' + '<div class="photobox posrel">' + '<div class="posabs txtc fontlig color2 f14 lh30 pum35 dispnone retryMessage"><i class="up_sprite pu_retry pu_mt2"></i>Retry</div>' + "<img class='classimg1 opa50 uploading" + count + "' src='" + picFile.result + "'" + "title='" + picFile.name + "'/>" + '<div class="posabs pu_pos1" onclick="deleteThisPhoto(' + count + ')"><a href="#" class="up_sprite pu_cross"></a></div>' + '<div class="posabs fullwid pu_pos2 uploadingBar' + count + '">' + '<div class="wid80p brdr12">' + '<div class="bg7 hgt10 mrl0 uploadingPercent' + count + '" style="width:0px;"></div>' + '</div></div></div></div>'; 
       output.insertBefore(div, existingNode); 
       generatingDiv.innerHTML = ""; 
       formDataArray[count] = dataToBeSent; 

      }; 
      picReader.readAsDataURL(file); //Read the image 
     } 
+0

Если возможно, может опубликовать 'js'? Спасибо – guest271314

ответ

1

Объект File имеет type свойство, содержащее мим Тип:

for (var i = 0; i < files.length; i++) { 
    var file = files[i]; 
    var fileType = file.type; 
    console.log(fileType); // image/png 
} 

объект FileReader возвращает строку base64, которая имеет тип пантомимы, а также, что вы можете извлечь с помощью этой функции:

function base64MimeType(encoded) { 
    if (!encoded) return; 
    var mime = encoded.match(/data:([a-zA-Z0-9]+\/[a-zA-Z0-9-.+]+).*,.*/); 

    if (mime && mime.length) return mime[1]; 
} 

var picReader = new FileReader(); 
picReader.readAsDataURL(file); 
var base64 = picReader.result; 
console.log(base64MimeType(base54)); // image/png 

JSFiddle демо: http://jsfiddle.net/mr2g5dx1/2/

Вот небольшой модуль я создал: https://github.com/miguelmota/base64mime

+0

проверено на sony xperia L версии 4.1, тип неподвижного изображения равен нулю при предупреждении :( – user1850796

+0

@ user1850796 Что вы получаете, когда вы делаете 'alert (JSON.stringify (файл))'? –

+0

Он возвращает массив файлов с указанием имени, размер, LastModifiedDate и тип. , но тип пуст (type = ""). на родном браузере Android (4.2) –

Смежные вопросы