开发者问题收集

node.js、sigma.js 和 typescript 环境中未定义窗口

2022-01-21
802

我尝试使用 TypeScript 编写的 node.js 设置 sigma.js 项目。使用以下命令启动 node.js 服务器后出现以下引用错误:

ts-node index.ts

错误似乎直接发生在 sigma\utils\index.js 中。

<nodejsproject>\node_modules\sigma\utils\index.js:125
    if (typeof window.devicePixelRatio !== "undefined")
    ^
ReferenceError: window is not defined
    at getPixelRatio (<nodejsproject>\node_modules\sigma\utils\index.js:125:5)
    at Object.<anonymous> (<nodejsproject>\node_modules\sigma\sigma.js:52:45)
    at Module._compile (node:internal/modules/cjs/loader:1101:14)
    at Object.Module._extensions..js (node:internal/modules/cjs/loader:1153:10)
    at Module.load (node:internal/modules/cjs/loader:981:32)
    at Function.Module._load (node:internal/modules/cjs/loader:822:12)
    at Module.require (node:internal/modules/cjs/loader:1005:19)
    at require (node:internal/modules/cjs/helpers:102:18)
    at Object.<anonymous> (<nodejsproject>\node_modules\sigma\index.js:14:31)
    at Module._compile (node:internal/modules/cjs/loader:1101:14)

我尝试按如下方式设置 typescript 配置:

package.json

{
  ...
  "main": "index.ts",
  "scripts": {
    "dev": "nodemon ./index.ts",
    "test": "echo \"Error: no test specified\" && exit 1",
    "start": "ts-node index.ts"
  },
  "dependencies": {
    "@types/sigmajs": "^1.0.28",
    "express": "^4.17.2",
    "fs": "^0.0.1-security",
    "graphology": "^0.23.2",
    "graphology-components": "^1.5.2",
    "graphology-layout": "^0.5.0",
    "graphology-layout-forceatlas2": "^0.8.1",
    "papaparse": "^5.3.1",
    "path": "^0.12.7",
    "sigma": "^2.1.3",
    "xhr": "^2.6.0"
  },
  "devDependencies": {
    "@types/express": "^4.17.13",
    "tslint": "^6.1.3",
    "typescript": "^4.5.5"
  }
}

tsconfig.json

{
  "compilerOptions": {
    "module": "commonjs",
    "esModuleInterop": true,
    "target": "es6",
    "moduleResolution": "node",
    "sourceMap": true,
    "outDir": "dist",
    "lib": ["dom"]
  },
  "lib": [
    "es2015"
  ],
  "exclude":[
    "./node_modules"
  ]
}

实例化 Sigma 以绘制图形后出现错误:

router.get('/', (request, response) => {
    
    response.sendFile(path.join(__dirname+'/views/index.html'));
    
    const file = fs.createReadStream(fileLocation);
    
    //Metadata were loaded and parsed
    Papa.parse<{ original_table: string; referenced_table: string }>(file, {
      download: true,
      header: true,
      delimiter: ';',
      complete: (results) => {
        const graph: Graph = new Graph();
            
        //Build the node with their entities as nodes
        results.data.forEach((line) => {

        /* process loaded data to create the graph */

        //Draw the graph within the browser
        const container = document.getElementById("network-container") as HTMLElement;
        
        new Sigma(graph, container); //error occurs right here
      },
    });
});
1个回答

嗯,不是。

Express.js 是一个服务器端框架,用于生成对 HTTP 请求的响应。它在 Node.js 上运行。它没有窗口。

Sigma 是一个图形库,旨在嵌入到网页中时由 Web 浏览器运行(通过 <script> 元素)。它通过操作该网页的 DOM 来工作。

它与 Node.js 或 Express.js 不兼容。


NPM 上存在软件包不应被理解为模块与 Node.js 兼容。那里的许多模块都是为使用 NPM 管理其依赖项的应用程序在 Web 浏览器中使用的。(这些通常是使用 React、Angular 或 Vue 等 SPA 框架编写的应用程序,它们使用 Webpack 或 Parcel 等工具捆绑它们所依赖的模块)。

Quentin
2022-01-21