函数处理的不是变量的最后一条语句?

我正在编写这段代码,目标是:检查是否是PNG,检查是否是256X256,并将img转换为base64以上传到服务器。

因此,如果我选择 256 x 256 img,它会加载,但是,如果我在选择 256 x 256 后加载另一个不是 256 x 256 的 img,它会加载,我不知道为什么!我该如何解决?

function isFileImage(file) {

    const acceptedImageTypes = ['image/png'];


    return file && acceptedImageTypes.includes(file['type'])

}




function importFileandPreview() {

  var preview = document.querySelector('img');

  var file    = document.querySelector('input[type=file]').files[0];

  var reader  = new FileReader();


  if (file) {

    //read img

    reader.readAsDataURL(file);

    //verify type

    var text = file.type;

    if (text === "image/png") {

      //load img

      reader.addEventListener("load", function () {

        //put img on <img> src

        //console logs

        //console.log(preview);

        //console.log("pre_nat_height:"+preview.naturalHeight);

      // console.log("pre_nat_width:"+preview.naturalWidth);

       //technically check if img is 256 x 256

       var old = preview.src;

       preview.src = reader.result;

        if(preview.naturalHeight === 256 && preview.naturalWidth === 256){

          //create a hidden input (works but value is not from last img)

          var element = document.getElementById("imga");

            if(typeof(element) != 'undefined' && element != null){

            document.getElementById("imga").remove();

          }

            input = document.createElement('input');

            input.setAttribute("type","hidden");

            input.setAttribute("id","imga");

            input.setAttribute("name","img")

            input.setAttribute("value",preview.src);

            document.getElementById('count').appendChild(input);


            delete preview;

        }

        //else if img is not 256 x 256

        else {

          preview.src = old;

          alert("Must be a PNG and have 256px X 256px!");

          delete preview;

        }

      }, false);// i don't know why false but ye

    }

  }

}

<input type="file" id="file" accept="image/PNG" onchange="importFileandPreview()"><br>

<form id="count">

</form>


繁星coding
浏览 70回答 1
1回答

叮当猫咪

您需要在预览事件的处理程序内对图像的自然尺寸进行检查load。你所面临的问题是由于时机不当而不是逻辑错误造成的。更具体地说,它在于您设置新的预览,然后同步src检查加载图像的自然尺寸。这种方法是错误的,因为图像是异步加载的,因此您的代码不会等待它加载后再继续检查。因此,当您在选择有效图像后选择无效图像时,您仍然会检查前者的尺寸,因为后者尚未加载。要更正此错误,您必须在预览事件的处理程序内执行检查load,如下所示。工作片段:(我重写了该函数以使其更易于阅读)function isFileImage (file) {&nbsp; &nbsp; const acceptedImageTypes = ["image/png"];&nbsp; &nbsp; return file && acceptedImageTypes.includes(file["type"])}function importFileandPreview () {&nbsp; &nbsp; var preview = document.querySelector("img");&nbsp; &nbsp; var file&nbsp; &nbsp; = document.querySelector("input[type=file]").files[0];&nbsp; &nbsp; var reader&nbsp; = new FileReader();&nbsp; &nbsp; /* Terminate the function prematurely if the file isn't an image. */&nbsp; &nbsp; if (!isFileImage(file)) return;&nbsp; &nbsp; /* Load the file into the reader. */&nbsp; &nbsp; reader.readAsDataURL(file);&nbsp; &nbsp; /* Set the 'load' event of the reader. */&nbsp; &nbsp; reader.addEventListener("load", function () {&nbsp; &nbsp; &nbsp; &nbsp; /* Create a temporary image to use for the check to avoid flashing. */&nbsp; &nbsp; &nbsp; &nbsp; var tempPreview = new Image();&nbsp; &nbsp; &nbsp; &nbsp; /* Set the 'load' event of the temporary preview. */&nbsp; &nbsp; &nbsp; &nbsp; tempPreview.addEventListener("load", function () {&nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; /* Check whether the selected image isn't 256x256 pixels. */&nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; if (this.naturalHeight != 256 || this.naturalWidth != 256) {&nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; /* Alert the user. */&nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; alert("Must be a PNG and have 256px X 256px!");&nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; /* Restore the default src to the preview. */&nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; preview.src = preview.dataset.defaultSrc;&nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; /* Terminate the function prematurely. */&nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; return;&nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; }&nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; /* Set the result of the reader as the source of the preview. */&nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; preview.src = reader.result;&nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; /* Save the image to the form. */&nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; saveImageToInput(reader.result);&nbsp; &nbsp; &nbsp; &nbsp; });&nbsp; &nbsp; &nbsp; &nbsp; /* Set the result of the reader as the source of the image. */&nbsp; &nbsp; &nbsp; &nbsp; tempPreview.src = reader.result;&nbsp; &nbsp; });&nbsp; &nbsp; /* Save the default image in a data-* attribute to use again if needed. */&nbsp; &nbsp; preview.dataset.defaultSrc = preview.dataset.defaultSrc || preview.src;}function saveImageToInput (image) {&nbsp; &nbsp; /* Find the hidden input. */&nbsp; &nbsp; var input = document.getElementById("imga");&nbsp; &nbsp; /* Check whether the input doesn't exist. */&nbsp; &nbsp; if (!input) {&nbsp; &nbsp; &nbsp; &nbsp; /* Create a new hidden input. */&nbsp; &nbsp; &nbsp; &nbsp; input = document.createElement("input");&nbsp; &nbsp; &nbsp; &nbsp; input.setAttribute("id", "imga");&nbsp; &nbsp; &nbsp; &nbsp; input.setAttribute("name", "img");&nbsp; &nbsp; &nbsp; &nbsp; input.setAttribute("type", "hidden");&nbsp; &nbsp; &nbsp; &nbsp; /* Place the input in the form. */&nbsp; &nbsp; &nbsp; &nbsp; document.getElementById("count").appendChild(input);&nbsp; &nbsp; }&nbsp; &nbsp; /* Save the image as the input's value. */&nbsp; &nbsp; input.setAttribute("value", image);}<input type="file" id="file" accept="image/PNG" onchange="importFileandPreview()"><br><img src=" " height="256" width="256"><form id="count"></form>笔记:最好使用临时预览来检查所选图像是否满足您的条件,因为如果您将其加载到可见预览中然后提醒用户,则将显示加载的图像。delete preview: 不要这样做。JavaScript 中的变量不应该像这样被删除。传递给的第三个参数addEventListener确定事件是在冒泡阶段还是捕获阶段捕获。默认情况下,它是false,因此您可以省略它。
打开App,查看更多内容
随时随地看视频慕课网APP

相关分类

JavaScript