Отправьте форму с помощью Javascript и обработайте ее с помощью ajaxForm - PullRequest
0 голосов
/ 26 января 2019

В настоящее время я изменяю свою систему, чтобы при загрузке формы отображался индикатор выполнения загрузки.

В моей старой системе у меня была эта форма и этот скрипт, чтобы проверить, существует ли файл и имеет ли он правильный формат:

Index.php

<form  method="POST" enctype="multipart/form-data" id="myForm" action="upload.php">

    <input type="file" name="imageSent" id="imgFile" class="inputImg" />
    <label for="imgFile" class="labelForImgF">
        <span>Select Img</span>
    </label>

    <button type="button" class="btnSubmit" onclick='verifyImg();'>
        <span>Send</span>
    </button>

</form>

    <script>
function verifyImg() {
    document.getElementById("warning").innerHTML = "";
    var fileName = document.getElementById("imgFile");
    if(fileName.files.item(0) == null) {
        document.getElementById("warning").innerHTML = "You must select an img";
    } else {
        if(!isValidFileType(fileName.files.item(0).name,'image')) {
            document.getElementById("warning").innerHTML = "Bad format";
        } else {
            document.getElementById('myForm').submit();
            document.getElementById("warning").innerHTML = "Sucess";
        }
    }
}

var extensionLists = {}; 
extensionLists.image = ['jpg', 'nef', 'bmp', 'png', 'jpeg', 'svg', 'webp', '3fr', 'arw', 'crw', 'cr2', 'cr3', 'dng', 'kdc', 'mrw', 'nrw', 'orf', 'ptx', 'pef', 'raf', 'R3D', 'rw2', 'srw', 'x3f'];

function isValidFileType(fName, fType) {
return extensionLists[fType].indexOf(fName.toLowerCase().split('.').pop()) > -1;
}
</script>

А вот моя новая система, она хорошо работает с ajax, но я не могу проверить, правильный ли формат, потому что, пока я добавляю onclick:verifyImg(); в свою кнопку, форма отправляется без прохождения через систему Ajax.

Вот мой новый код:

<form  method="POST" enctype="multipart/form-data" id="myForm" action="upload.php">

    <input type="file" name="imageSent" id="imgFile" class="inputImg" />
    <label for="imgFile" class="labelForImgF">
        <span>Select Img</span>
    </label>

    <button class="btnSubmit">
        <span>Send</span>
    </button>

</form>
<div id="bararea">
    <div id="bar"></div>
</div>

<div id="percent"></div>
<div id="status"></div>
<script>
$(function() {
$(document).ready(function(){
    var bar = $('#bar')
    var percent = $('#percent');
    var status = $('#status');

    $('form').ajaxForm({
        beforeSend: function() {
            status.empty();
            var percentVal = '0%';
            bar.width(percentVal);
            percent.html(percentVal);
        },
        uploadProgress: function(event, position, total, percentComplete) {
            var percentVal = percentComplete + '%';
            percent.html(percentVal);
            bar.width(percentVal);
        },
        complete: function(xhr) {
            status.html(xhr.responseText);
        }
    });
});
});
</script>

Эти две системы хорошо работают по отдельности, но я не могу их смешать, чтобы проверить мою форму с помощью javascript и отправить ее с помощью Ajax.

Думаю, я не очень хорошо понимаю, как работает Ajax, вы можете мне помочь?

Я новичок, пожалуйста, будьте снисходительны.

Решение: Я попробовал Chris G ответить и изменил функцию beforeSend by beforeSubmit, и теперь она отлично работает.

Код:

<form  method="POST" enctype="multipart/form-data" id="myForm" action="upload.php">

    <input type="file" name="imageSent" id="imgFile" class="inputImg" />
    <label for="imgFile" class="labelForImgF">
        <span>Select Img</span>
    </label>

    <button class="btnSubmit">
        <span>Send</span>
    </button>

</form>
<div id="bararea">
    <div id="bar"></div>
</div>

<div id="percent"></div>
<div id="status"></div>
    <script>
function verifyImg() {
    document.getElementById("warning").innerHTML = "";
    var fileName = document.getElementById("imgFile");
    if(fileName.files.item(0) == null) {
        document.getElementById("warning").innerHTML = "You must select an img";
        return false;
    } else {
        if(!isValidFileType(fileName.files.item(0).name,'image')) {
            document.getElementById("warning").innerHTML = "Bad format";
            return false;
        } else {
            return true;
            document.getElementById("warning").innerHTML = "Sucess";
        }
    }
}

var extensionLists = {}; 
extensionLists.image = ['jpg', 'nef', 'bmp', 'png', 'jpeg', 'svg', 'webp', '3fr', 'arw', 'crw', 'cr2', 'cr3', 'dng', 'kdc', 'mrw', 'nrw', 'orf', 'ptx', 'pef', 'raf', 'R3D', 'rw2', 'srw', 'x3f'];

function isValidFileType(fName, fType) {
return extensionLists[fType].indexOf(fName.toLowerCase().split('.').pop()) > -1;
}
</script>
<script>
$(document).ready(function(){
    var bar = $('#bar')
    var percent = $('#percent');
    var status = $('#status');

    $('form').ajaxForm({
        beforeSubmit: function() {
            if (!verifyImg()) return false ;
            status.empty();
            var percentVal = '0%';
            bar.width(percentVal);
            percent.html(percentVal);
        },
        uploadProgress: function(event, position, total, percentComplete) {
            var percentVal = percentComplete + '%';
            percent.html(percentVal);
            bar.width(percentVal);
        },
        complete: function(xhr) {
            status.html(xhr.responseText);
        }
    });
});
</script>

1 Ответ

0 голосов
/ 26 января 2019

используйте этот код, я проверял, он работает хорошо. Если вы хотите проверить ход загрузки, в консоли браузера Google выберите network →, затем выберите медленный 3G здесь: simulate slow network

в противном случае вы не сможете увидеть прогресс загрузки, вы увидите 100% во флэш-памяти, если ваша фотография не имеет чрезвычайно большой размер.

пользователь не может выбрать не файл изображения, добавив атрибут accept в поле ввода accept="image/*", даже если этот атрибут не используется, javascript будет проверять формат файла по этому коду, вы можете добавить другие типы здесь, если вам нужно "(jpeg | png | bmp)":

    var file = $('input[name="photo"]').get(0).files[0];
    var matchArr = file.type.match(/image\/(jpeg|png|bmp)/);
    if (!matchArr) {
      alert("file type not allow!");
      return false;
    }

Это полный код:

$(document).ready(function() {
  $('input[type="button"]').on('click', function() {
    var file = $('input[name="photo"]').get(0).files[0];
    var matchArr = file.type.match(/image\/(jpeg|png|bmp)/);
    if (!matchArr) {
      alert("file type not allow!");
      return false;
    }

    var words = $('input[name="words"]').val();
    var formData = new FormData();
    formData.append('photo', file);
    formData.append('words', words);

    $.ajax({
      type: 'post',
      url: '',
      data: formData,
      //contentType must be false(otherwise it will use default value:application/x-www-form-urlencoded; charset=UTF-8, which is wrong)
      contentType: false,
      //tell jquery don't process data(otherwise it will throw an error:Uncaught TypeError: Illegal invocation)
      processData: false,
      xhr: function() {
        let xhr = new XMLHttpRequest();
        //listening upload progress
        xhr.upload.addEventListener('progress', function(e) {
          if (e.lengthComputable) {
            let progress = e.loaded / e.total;
            progress = Math.round(progress * 10000) / 100 + '%';
            $('.upload-progress').html(progress);
          }
        }, false);
        return xhr;
      },
      success: function(response) {
        console.log(response);
      }
    });
    return false;
  });
});
<html>

<head>
  <title>AjaxFormDataUpload</title>
  <meta content="width=device-width, initial-scale=1.0, maximum-scale=1.0, user-scalable=0" name="viewport" />
  <script src="http://apps.bdimg.com/libs/jquery/2.1.1/jquery.min.js"></script>
  <style>
    #upload-form {
      width: 50%;
      margin: 0 auto;
      border: 1px solid blue;
    }
    
    .field {
      padding: 10px;
    }
    
    .submit-btn {
      text-align: center;
      font-size: 20px;
    }
  </style>
</head>

<body>
  <form id="upload-form">
    <div class="field">
      <input type="file" name="photo" accept="image/*">
      <span class="upload-progress"></span>
    </div>
    <div class="field">
      <input type="text" name="words">
    </div>
    <div class="submit-btn">
      <input type="button" value="submit">
    </div>
  </form>
</body>

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