it-swarm.com.de

so verwenden Sie ein CDN in einer React-Komponente

Ich habe eine ähnliche Frage gefunden, aber keine der Antworten verstanden (und die Frage wurde abgelehnt).

Ich versuche, eine auf D3 basierende Bibliothek namens Greuler zu verwenden, um Diagramme dynamisch zu rendern. Das npm-Paket dafür scheint kaputt zu sein. Als ich auf das Greuler-CDN umgestiegen bin, hat der Testgraph in meiner index.html endlich funktioniert. 

Ich arbeite jedoch an einer React-App und möchte, dass das Diagramm aus einer React-Komponente dargestellt wird. Hier tritt das Problem auf: Die React-Komponente verwendet nicht die Greuler-CDN-Skripts, die sich in meiner index.html befinden, und ich habe mehrere Möglichkeiten zum Ausführen der Skripts in meiner Komponente versucht, aber es scheint nichts zu funktionieren. 

Die zwei Hauptfehler sind:

error 'greuler' is not defined (in meiner Komponente)

Uncaught TypeError: Cannot read property 'getAttribute' of null (im D3-Code)

Mein Arbeitsindex.html mit einem fest codierten Diagramm sieht wie folgt aus:

<!DOCTYPE html>
<html lang="en">
  <head>
    <meta charset="utf-8">
    <meta name="viewport" content="width=device-width, initial-scale=1">
    <title>Navigating Spinoza</title>
    <script src="https://cdnjs.cloudflare.com/ajax/libs/d3/3.5.6/d3.js"></script>
    <script src="http://marvl.infotech.monash.edu/webcola/cola.v3.min.js"></script>
    <script src="http://maurizzzio.github.io/greuler/greuler.min.js"></script>
  </head>
  <body>
    <div id="root"></div>
    <div class="row" id="demo">
      <script>
        var instance = greuler({
          target: '#demo',
          width: 480,
          height: 500,
          data: {
            nodes: [
              {id: 0, label: "E1Def3", r: 25},
              {id: 1, label: "E1P4", r: 15},
              {id: 2, label: "E1P2", r: 15},
              {id: 3, label: "E1P1", r: 15},
              {id: 4, label: "E1P5", r: 15},
              {id: 5, label: "E1P6", r: 25}
            ],
            links: [
              {source: 0, target: 1, directed: true},
              {source: 0, target: 2, directed: true},
              {source: 0, target: 3, directed: true},
              {source: 1, target: 4, directed: true},
              {source: 2, target: 5, directed: true},
              {source: 3, target: 4, directed: true},
              {source: 4, target: 5, directed: true}
            ]
          }
        }).update()
      </script>
    </div>
  </body>
</html>

Mein letzter verzweifelter Versuch der Renderfunktion in der Komponente sieht folgendermaßen aus:

render() {
    return (
     <div class="row" id="demo">
    <script src="https://cdnjs.cloudflare.com/ajax/libs/d3/3.5.6/d3.js"></script>
    <script src="http://marvl.infotech.monash.edu/webcola/cola.v3.min.js"></script>
    <script src="http://maurizzzio.github.io/greuler/greuler.min.js"></script>
     { 
        greuler({
          target: '#demo',
          width: 480,
          height: 500,
          data: {
            nodes: [
              {id: 0, label: "E1Def3", r: 25},
              {id: 1, label: "E1P4", r: 15},
              {id: 2, label: "E1P2", r: 15},
              {id: 3, label: "E1P1", r: 15},
              {id: 4, label: "E1P5", r: 15},
              {id: 5, label: "E1P6", r: 25}
            ],
            links: [
              {source: 0, target: 1, directed: true},
              {source: 0, target: 2, directed: true},
              {source: 0, target: 3, directed: true},
              {source: 1, target: 4, directed: true},
              {source: 2, target: 5, directed: true},
              {source: 3, target: 4, directed: true},
              {source: 4, target: 5, directed: true}
            ]
          }
        }).update()
      }
    </div>
      </div>
    );
  }
}
7
jaimefps

Die beste/einfachste Lösung wäre, eine Stub-Datei index.html zu haben, die die benötigten Skripts enthält (Sie können Bibliotheken von npm installieren, da andere vorgeschlagen haben, dies funktioniert jedoch für Bibliotheken, die nur über ein CDN verfügen). So hätten Sie eine index.html-Datei wie folgt:

<!DOCTYPE html>
<html lang="en">
  <head>
    <meta charset="utf-8">
    <meta name="viewport" content="width=device-width, initial-scale=1">
    <title>Navigating Spinoza</title>
    <script src="https://cdnjs.cloudflare.com/ajax/libs/d3/3.5.6/d3.js"></script>
    <script src="http://marvl.infotech.monash.edu/webcola/cola.v3.min.js"></script>
    <script src="http://maurizzzio.github.io/greuler/greuler.min.js"></script>
  </head>
  <body>
    <div id="root"></div>
    <div class="row" id="demo"></div>
  </body>
</html>

Und dann eine Reaktionskomponente wie diese (ich habe etwas Code verschoben, um einigen Reaktionsidiomen besser folgen zu können):

var Component = React.createClass({    
  componentDidMount:function() {
    greuler({
      target: '#chart',
      width: 480,
      height: 500,
      data: {
        nodes: [
          {id: 0, label: "E1Def3", r: 25},
          {id: 1, label: "E1P4", r: 15},
          {id: 2, label: "E1P2", r: 15},
          {id: 3, label: "E1P1", r: 15},
          {id: 4, label: "E1P5", r: 15},
          {id: 5, label: "E1P6", r: 25}
        ],
        links: [
          {source: 0, target: 1, directed: true},
          {source: 0, target: 2, directed: true},
          {source: 0, target: 3, directed: true},
          {source: 1, target: 4, directed: true},
          {source: 2, target: 5, directed: true},
          {source: 3, target: 4, directed: true},
          {source: 4, target: 5, directed: true}
        ]
      }
    }).update()
  }

  render() {
    return (
      <div id="chart"></div>
    );
  }
}

ReactDOM.render(<Component />, document.querySelector('root'));

Dies ist eine einfache Lösung, die mehr leisten kann (z. B. den Zustand und die Eigenschaften von use reagieren, um Parameter zu übergeben), aber dies sollte eine allgemeine Vorstellung von der Lösung geben. In diesem Code wird außerdem davon ausgegangen, dass Sie die React- und ReactDOM-Bibliotheken auf eine bestimmte Art (babel, CDN usw.) enthalten haben.

4
Jordan

Versuche dies: 

<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="utf-8">
<meta name="viewport" content="width=device-width, initial-scale=1">
<title>Navigating Spinoza</title>
</head>
<body>
<div id="root"></div>
<div class="row" id="demo"></div>
<script src="https://cdnjs.cloudflare.com/ajax/libs/d3/3.5.6/d3.js">
</script>
<script src="http://marvl.infotech.monash.edu/webcola/cola.v3.min.js">
</script>
<script src="http://maurizzzio.github.io/greuler/greuler.min.js"></script>
<script>
    import React from 'react'
    import { render } from 'react-dom'

    var Instance = greuler({
      target: '#demo',
      width: 480,
      height: 500,
      data: {
        nodes: [
          {id: 0, label: "E1Def3", r: 25},
          {id: 1, label: "E1P4", r: 15},
          {id: 2, label: "E1P2", r: 15},
          {id: 3, label: "E1P1", r: 15},
          {id: 4, label: "E1P5", r: 15},
          {id: 5, label: "E1P6", r: 25}
        ],
        links: [
          {source: 0, target: 1, directed: true},
          {source: 0, target: 2, directed: true},
          {source: 0, target: 3, directed: true},
          {source: 1, target: 4, directed: true},
          {source: 2, target: 5, directed: true},
          {source: 3, target: 4, directed: true},
          {source: 4, target: 5, directed: true}
        ]
      }
    }).update()

    render(
      <Instance />,
      document.getElementById('root')
    )
  </script>
</body>
</html>
1
JuMoGar

Installieren Sie das Modul mit npm:

npm install greuler

Siehe hier: https://www.npmjs.com/package/greuler

Dann verwenden Sie in Ihrer Komponente:

var greuler = require('greuler')
0
Toby

Sie müssen einen Modul Bundler like webpack oder browserify verwenden und anschließend die Bibliothek importieren.

npm install greuler

var greuler = require('greuler')

0
Jonathan Dion