How to use D3 in Node.js properly?

前端 未结 3 1098
别跟我提以往
别跟我提以往 2020-12-02 10:06

I\'ve been trying to invoke D3 within Node.js. I tried firstly to import d3.v2.js from D3\'s website with the script tag, but then read this thread:

I want to run d3

相关标签:
3条回答
  • 2020-12-02 10:32

    You need to install jsdom using yarn or npm. Node.js does not support dom by default, thus the need to use jsdom for creating dom elements. Use d3 for all other manipulations except fetch operations. i.e d3.xml,d3.tsv

    import jsdom from 'jsdom';
    import * as d3 from 'd3';
    const { JSDOM } = jsdom;
    JSDOM.fromURL(
        'your resource url',
      ).then((dom) => {
        const doc = dom.window.document;
        const states = d3
          .select(doc)
          .select('path')
          .attr(':fme:ID');
        console.log(states);
      });
    

    creating dom from file

    JSDOM.fromURL(
        'your resource url',
      ).then((dom) => {
        const doc = dom.window.document;
    }
    

    dom from html string

    const dom = new JSDOM(
      `<p>Hello
        <img src="foo.jpg">
      </p>`,
      { includeNodeLocations: true }
    );
    
    
    0 讨论(0)
  • 2020-12-02 10:42

    The correct way to use D3 within Node is to use NPM to install d3 and then to require it. You can either npm install d3 or use a package.json file, followed by npm install:

    {
      "name": "my-awesome-package",
      "version": "0.0.1",
      "dependencies": {
        "d3": "3"
      }
    }
    

    Once you have d3 in your node_modules directory, load it via require:

    var d3 = require("d3");
    

    And that's it.

    Regarding your other issues: Canvas is not required to use D3. The node-canvas example you linked requires canvas because it renders to a canvas. The TypeError (Cannot read property 'BSON' of undefined) appears to be related to your use of mongoose / monogdb, not D3.

    0 讨论(0)
  • 2020-12-02 10:44

    To use with ES6's import instead of require:

    import * as d3 from 'd3';
    

    This is perhaps obvious to any experienced babel/ES6-user, and I know this is an old question, but I came here in an attempt to figure this out. Hope this is helpful for someone.

    More on import vs. require is found here.

    0 讨论(0)
提交回复
热议问题