Ошибка: не удалось загрузить скрипт с приложением app.js - PullRequest
0 голосов
/ 17 февраля 2019

У меня есть простой скрипт для запуска CCapture.js на стороне сервера node.js

Вот app.js

const jsdom = require("jsdom");
const { JSDOM } = jsdom;
const fs = require("fs");
const _ = require("lodash");

const { window } = new JSDOM(
  `
<body>
   <script src='./node_modules/ccapture.js/build/CCapture.all.min.js'></script>
    <canvas id='animation' width='400' height='200'></canvas>
</body>
`,
  // We need these options to allow JSDOM to require CCapture from node_modules
  { runScripts: "dangerously", resources: "usable" }
);

const document = window.document;

// Do our stuff after DOM is ready.
window.onload = () => {
  const canvas = document.getElementById("animation");
  const ctx = canvas.getContext("2d");

  // Doing some random animation here
  const render = () => {
    ctx.fillStyle = "blue";
    ctx.font = "30px Impact";
    ctx.rotate(_.random(0.1, 0.2));
    ctx.fillText("Awesome!", 50, 100);
  };

  // Framerate for capturer is 1 per second just for example
  const capturer = new window.CCapture({
    format: "png",
    framerate: 1,
    verbose: true
  });

  capturer.start();

  // Doing 3 renders, and capture the canvas
  const interval = setInterval(() => {
    render();
    capturer.capture(canvas);
  }, 1000);

  // Now clearing the interval, stopping capturer
  setTimeout(() => {
    clearInterval(interval);

    capturer.stop();

    // Saving the file using FileReader (from JSDOM) and node.js API
    capturer.save(blob => {
      const reader = new window.FileReader();
      reader.onload = () => {
        const arrayBuffer = reader.result;
        const uint8Array = new Uint8Array(arrayBuffer);

        // Sync for simplicity
        fs.writeFileSync("./images.tar", uint8Array, { encoding: "binary" });
      };

      reader.readAsArrayBuffer(blob);
    });
  }, 4000);
};

Когда я запускаю node app.js, к сожалению, яполучить следующую ошибку.

Error: Could not load script: "./node_modules/ccapture.js/build/CCapture.all.min.js"

Здесь я stree моего сайта

.
├── app.js
├── css
│   └── main.css
├── index.html
├── js
│   ├── CCapture.all.min.js
│   └── main.js
├── node_modules
    ├── ccapture.js
    │   │   ├── bower.json
    │   │   ├── build
    │   │   │   ├── CCapture.all.min.js
    │   │   │   └── CCapture.min.js
    │   │   ├── LICENSE
    │   │   ├── package.json
    │   │   ├── README.md
    │   │   └── src
    │   │       ├── CCapture.js
    │   │       ├── download.js
    │   │       ├── gif.js
    │   │       ├── gif.worker.js
    │   │       ├── tar.js
    │   │       ├── webm-writer-0.2.0.js
    │   │       └── Whammy.js

    ........

что не так с моим кодом?

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