当我单击“上传”按钮时,警报不会出现

Alert doesn't appear when I click on the "Upload" button

本文关键字:单击 上传 按钮      更新时间:2023-09-26

我想执行一个简单的javascript验证,当用户单击表单中的提交按钮时,它将检查文件是"png"还是"gif"文件类型。如果文件类型正确,则显示加载栏并上传表单。如果文件类型不正确,则显示 n 条警报,指出文件类型不正确,但不显示加载栏,也不上传表单。

下面是代码,但当我单击"上传"按钮时,它没有显示警报。我需要做什么,以便当用户单击"上传"按钮时,如果文件类型不正确,则会出现警报并且它不会上传文件,如果文件类型正确,则会显示加载栏并上传文件。

var sourceImageForm;
var $fileImage = $("<form action='imageupload.php' method='post' enctype='multipart/form-data' target='upload_target' onsubmit='startImageUpload(this);' class='imageuploadform' >" + 
"<label> Image File: <input name='fileImage' type='file' class='fileImage' /></label><br/>" +
"<input type='submit' name='submitImageBtn' class='sbtnimage' value='Upload' /></label></form>");
function startImageUpload(imageuploadform){
    $(".imageFile").change(function() {
    var val = $(this).val();
    switch(val.substring(val.lastIndexOf('.') + 1).toLowerCase()){
        case 'gif': case 'jpg': case 'png':
        return true;
            break;
        default:
            $(this).val('');
            alert("not an image");
            return false;
            break;
    }
});
  $(imageuploadform).find('.imagef1_upload_process').css('visibility','visible');
  $(imageuploadform).find('.imagef1_upload_form').css('visibility','hidden');
  sourceImageForm = imageuploadform;
      return true;
}

你错过了第三行的结束",这可能是原因。

你没有阻止表单默认行为,所以当你提交它时,它只是去,它不关心javascript方面。

$('form').submit(function(ev) {
// do your stuff here and return true to submit it or false to stop it
})
编辑:抱歉您在提交时确实绑定了,但是提交时您

所做的只是在更改时绑定图像元素,您实际上并没有在提交时检查任何内容