微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

JS:函数在控制台中手动工作,但在代码中不会自动执行

如何解决JS:函数在控制台中手动工作,但在代码中不会自动执行

我从这里复制了这个代码片段:https://codepen.io/duketeam/pen/ALEByA

代码应该加载图片并在单击按钮后使其变为灰度。 我想更改代码,使图片无需单击按钮即可立即以灰度显示,因此我将其注释掉并在 makeGray() 的加载部分中包含 <input...>。但这不起作用。我哪里出错了?

我试图省略 makeGray() 并只上传图片并在控制台中输入 makeGray() 并且它的工作非常好,但我需要它自动执行。我还尝试将 makeGray() 函数中的所有代码都放在 upload() 函数中,但在这里它也不会触发。

var image = null;

function upload() {
  //Get input from file input
  var fileinput = document.getElementById("finput");
  //Make new SimpleImage from file input
  image = new SimpleImage(fileinput);
  //Get canvas
  var canvas = document.getElementById("can");
  //Draw image on canvas
  image.drawTo(canvas);

}

function makeGray() {
  //change all pixels of image to gray
  for (var pixel of image.values()) {
    var avg = (pixel.getRed() + pixel.getGreen() + pixel.getBlue()) / 3;
    pixel.setRed(avg);
    pixel.setGreen(avg);
    pixel.setBlue(avg);
  }
  //display new image
  var canvas = document.getElementById("can");
  image.drawTo(canvas);
}
<script src="https://www.dukelearntoprogram.com/course1/common/js/image/SimpleImage.js">
</script>

<h1>Convert Image to Grayscale</h1>

<canvas id="can"></canvas>

<p>
  <input type="file" multiple="false" accept="image/*" id="finput" onchange="upload();makeGray()">

</p>
<p>
  <!---- <input type="button" value="Make Grayscale" onclick="makeGray()" -->
</p>
<script src="./index.js"></script>

解决方法

有些事情您需要等待,但我不确定到底是什么。如果您将函数包装在 setTimeout 中,它可以正常工作。您可能希望为系统较慢或文件较大的客户端多等待几毫秒。如果您想知道什么需要一段时间才能完成,为了安全起见,您可以改为使用 .thenawait

var image = null;

function upload() {
  //Get input from file input
  var fileinput = document.getElementById("finput");
  //Make new SimpleImage from file input
  image = new SimpleImage(fileinput);
  //Get canvas
  var canvas = document.getElementById("can");
  setTimeout(() => {
    //change all pixels of image to gray
    for (var pixel of image.values()) {
      var avg = (pixel.getRed() + pixel.getGreen() + pixel.getBlue()) / 3;
      pixel.setRed(avg);
      pixel.setGreen(avg);
      pixel.setBlue(avg);
    }
    image.drawTo(canvas);
  },100);
}
<script src="https://www.dukelearntoprogram.com/course1/common/js/image/SimpleImage.js">
</script>

<h1>Convert Image to Grayscale</h1>

<canvas id="can"></canvas>

<p>
  <input type="file" multiple="false" accept="image/*" id="finput" onchange="upload();">

</p>
<script src="./index.js"></script>

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。