невозможно просмотреть изображение перед загрузкой - PullRequest
0 голосов
/ 06 мая 2018

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

HTML

       <form action="#" id="mainpost">
                            <fieldset>
                                <div class="section postdetails">
                                    <div class="row form-group add-image">
                                        <label class="col-sm-3 label-title">Photos for your ad <span>(This will be your cover photo )</span> </label>
                                        <div class="col-sm-9">
                                            <h5><i class="flaticon-upload" aria-hidden="true"></i>Select Files to Upload<span>You can add multiple images.</span></h5>
                                            <div class="upload-section">
                                                <label class="upload-image" for="img1" id="preview-img1">
                                                    <input type="file" name="img1" id="img1">
                                                </label>                                        

                                                <label class="upload-image" for="img2" id="preview-img2">
                                                    <input type="file" name="img2" id="upload-image-two">
                                                </label>                                            
                                                <label class="upload-image" for="img3" id="preview-img3">
                                                    <input type="file" name="img3" id="upload-image-three" >
                                                </label>                                        

                                                <label class="upload-image" for="img4" id="preview-img4">
                                                    <input type="file" name="img4" id="upload-imagefour">
                                                </label>
                                            </div>  
                                        </div>
                                    </div>

                                </div><!-- section -->
                                </fieldset>
                        </form><!-- form -->    

Сценарий

function readURL(input) {
        if (input.files && input.files[0]) {
            var reader = new FileReader();

            reader.onload = function (e) {
                imgId = '#preview-' + $(input).attr('id');
                $(imgId).attr('src', e.target.result);
            };
            reader.readAsDataURL(input.files[0]);
        }
    }
    $("form#mainform div.upload-image input[type='file']").change(function () {
        readURL(this);
    });

1 Ответ

0 голосов
/ 06 мая 2018

В основном 2 ошибки

imgId = '#preview-' + $(input).attr('id');
$(imgId).attr('src', e.target.result);

Сначала вы пытаетесь присвоить атрибут src для label, а не для тега img, <label class="upload-image" for="img1" id="preview-img1">. Вы должны добавить тег <img> внутри каждой метки после ввода, а затем назначить src этому изображению id, который вы присвоили метке, присваивает его изображению <img class="upload-image" id="preview-img1" src="" />.

Тогда вы выбираете неправильную форму form#mainform и неправильный элемент div.upload-image

$("form#mainform div.upload-image input[type='file']")

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

$("form#mainpost label input[type='file']")

затем вы выбираете id для обнаружения элемента предварительного просмотра imgId = '#preview-' + $(input).attr('id');, тогда как вы должны выбрать атрибут name, чтобы соответствующий предварительный просмотр отображался на входе, см. Eblow, я создал демо

function readURL(input) {
  //console.log('here', input);
  if (input.files && input.files[0]) {
    var reader = new FileReader();
    reader.onload = function(e) {
      imgId = '#preview-' + $(input).attr('name');
      //console.log(imgId)
      $(imgId).attr('src', e.target.result);
    };
    reader.readAsDataURL(input.files[0]);
  }
}

$("form#mainpost label input[type='file']").on('change', function() {
  readURL(this);
});
img.upload-image {
  max-width: 100px;
  max-height: 100px;
  overflow: hidden;
}

label {
  display: inline-block;
}
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
<form action="#" id="mainpost">
  <fieldset>
    <div class="section postdetails">
      <div class="row form-group add-image">
        <label class="col-sm-3 label-title">Photos for your ad <span>(This will be your cover photo )</span> </label>
        <div class="col-sm-9">
          <h5><i class="flaticon-upload" aria-hidden="true"></i>Select Files to Upload<span>You can add multiple images.</span></h5>
          <div class="upload-section">
            <label for="img1">
            
                                                   <input type="file" name="img1" id="upload-image-one"><img class="upload-image" id="preview-img1" src="" />
                                                </label>

            <label for="img2">
            
                                                    <input type="file" name="img2" id="upload-image-two"><img class="upload-image" id="preview-img2"/>
                                                </label>
            <label classfor="img3">
            
                                                    <input type="file" name="img3" id="upload-image-three" ><img class="upload-image" id="preview-img3"/>
                                                </label>

            <label for="img4">
            
                                                    <input type="file" name="img4" id="upload-image-four"><img id="preview-img4"  class="upload-image" id="preview-img4"/>
                                                </label>
          </div>
        </div>
      </div>

    </div>
    <!-- section -->
  </fieldset>
</form>
<!-- form -->

EDIT

, так как вы не хотите или не можете изменить html, вы должны вручную создать элемент изображения и вставить его внутри метки

function readURL(input) {
  //console.log('here', input);
  if (input.files && input.files[0]) {
    var reader = new FileReader();
    reader.onload = function(e) {
      imgId = '#preview-' + $(input).attr('name');
      let img = document.createElement('img');
      img.setAttribute('src', e.target.result);
      img.setAttribute('class', 'img-preview');
      document.querySelector(imgId).appendChild(img);
      //console.log(imgId)
      //$(imgId).append('src', e.target.result);
    };
    reader.readAsDataURL(input.files[0]);
  }
}

$("form#mainpost label input[type='file']").on('change', function() {
  readURL(this);
});
img.img-preview {
  max-width: 100px;
  max-height: 100px;
  overflow: hidden;
}

label {
  display: inline-block;
}
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
<form action="#" id="mainpost">
  <fieldset>
    <div class="section postdetails">
      <div class="row form-group add-image">
        <label class="col-sm-3 label-title">Photos for your ad <span>(This will be your cover photo )</span> </label>
        <div class="col-sm-9">
          <h5><i class="flaticon-upload" aria-hidden="true"></i>Select Files to Upload<span>You can add multiple images.</span></h5>
          <div class="upload-section">
            <label class="upload-image" for="img1" id="preview-img1">
                                                    <input type="file" name="img1" id="img1">
                                                </label>

            <label class="upload-image" for="img2" id="preview-img2">
                                                    <input type="file" name="img2" id="upload-image-two">
                                                </label>
            <label class="upload-image" for="img3" id="preview-img3">
                                                    <input type="file" name="img3" id="upload-image-three" >
                                                </label>

            <label class="upload-image" for="img4" id="preview-img4">
                                                    <input type="file" name="img4" id="upload-imagefour">
                                                </label>
          </div>
        </div>
      </div>

    </div>
    <!-- section -->
  </fieldset>
</form>
<!-- form -->
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...