• Jobs
  • About Us
  • professionals
    • Home
    • Jobs
    • Courses and challenges
  • business
    • Home
    • Post vacancy
    • Our process
    • Pricing
    • Assessments
    • Payroll
    • Blog
    • Sales
    • Salary Calculator

0

110
Views
Usa React+D3 en Express

Estoy tratando de usar D3 en un componente React dentro de una aplicación Express . Parece que debería ser una tarea bastante fácil, pero seguir varios tutoriales no dirigidos a una aplicación Express no funcionó: en el ejemplo a continuación, obtengo un svg vacío ( <!DOCTYPE html><div><p>D3 Example</p><svg></svg></div> ) sin el círculo rojo.

Una posible explicación es que React.useEffect no se ejecuta en el servidor . Sin embargo, no entiendo por qué esto no se ejecuta después de cargar Javascript. En cualquier caso, no puedo encontrar cómo solucionar este problema, por lo que agradeceré cualquier ayuda para comprenderlo mejor o una solución :)


Enumero mi código relevante a continuación. Soy bastante nuevo con Node, así que traté de ceñirme a las convenciones de ejemplo de Express.

aplicación.js

 var simulationRouter = require('./routes/simulation'); var app = express(); app.set('views', path.join(__dirname, 'views')); app.set('view engine', 'jsx'); app.engine('jsx', require('express-react-views').createEngine()); ... app.use('/simulation', simulationRouter);

rutas/simulación.js

 var express = require('express'); var router = express.Router(); router.get('/', function(req, res, next) { res.render('d3_show_nolib'); }); module.exports = router;

vistas/d3_show_nolib.js

 import React, { useEffect, useRef } from "react"; import { select } from "d3"; export default function App() { const svgRef = useRef(); useEffect(() => { const svg = select(svgRef.current); const getData = () => { svg .append("circle") .attr("r", 15) .attr("fill", "red") .attr("stroke", 1.5); }; getData(); }, []); return ( <div> <p>D3 Exemple</p> <svg ref={svgRef}></svg> </div> ); }

(Espero que esto funcione como el siguiente archivo html único:

 <html> <head> <script src="https://d3js.org/d3.v7.min.js"></script> </head> <body> <svg id='svg'></svg> <script> var svg = d3.select('#svg'); svg.attr('width', 100) .attr('height', 100); svg .append("circle") .attr("r", 15) .attr("fill", "red") .attr("stroke", 1.5) .attr('cx', 10) .attr('cy', 10); </script> </body> </html>

)

almost 3 years ago · Juan Pablo Isaza
Answer question
Find remote jobs

Discover the new way to find a job!

Top jobs
Top job categories
Business
Post vacancy Pricing Our process Sales
Legal
Terms and conditions Privacy policy
© 2025 PeakU Inc. All Rights Reserved.

Andres GPT

Recommend me some offers
I have an error