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

0

156
Views
¿El componente web no está cargando el shadowDOM en una aplicación de reacción, pero se está cargando en una aplicación CRA nueva?

Seguí un tutorial de Maximillion ("Udemy") sobre componentes web y Stencil. Intenté agregar un código idéntico a mi entorno de desarrollo en una "aplicación de producción" y un nuevo proyecto "CRA (crear aplicación de reacción)".

¿Los resultados fueron que la "aplicación de producción" solo devolvió elementos HTML desnudos? ¿Sin sombra dom adjunta?

Ahora, el nuevo CRA pudo cargar y renderizar los componentes web a la perfección.

Estoy tratando de entender por qué sucede esto. Tengo la sospecha de que puede ser una cosa del paquete web, pero no estoy seguro.

Para reiterar el punto, ¿por qué el shadow dom no se procesa en mi aplicación de producción pero se procesa en mi aplicación POC de muestra?

about 3 years ago · Juan Pablo Isaza
1 answers
Answer question

0

En realidad, esta fue una solución simple, había seguido el Tutorial y los documentos al agregar esto:

 import { defineCustomElements } from 'web-components/loader/index.js'; defineCustomElements(window)

no a la página index.js como se indica --- este es el patrón recomendado --

 import React from 'react'; import ReactDOM from 'react-dom/client'; import './index.css'; import App from './App'; import reportWebVitals from './reportWebVitals'; import { defineCustomElements } from 'web-components/loader/index.js'; defineCustomElements(window) const root = ReactDOM.createRoot(document.getElementById('root')); root.render( <React.StrictMode> <App /> </React.StrictMode> ); // If you want to start measuring performance in your app, pass a function // to log results (for example: reportWebVitals(console.log)) defineCustomElements(window); reportWebVitals();

Esto no funcionó para mí en mi proyecto actual, pero funcionó muy bien para mí con un proyecto de construcción de CRA limpio y agradable.

Lo que terminé teniendo que hacer fue mover este código---

 import { defineCustomElements } from 'web-components/loader/index.js'; defineCustomElements(window)

a la parte superior de mi archivo de enrutador de reacción, luego funcionó perfectamente. Esto puede deberse al enrutador de reacción.

 // AboutPage/index.js import { Switch, Route } from 'react-router-dom'; import App from '../compopnents/App'; import { defineCustomElements } from 'web-components/loader/index.js'; defineCustomElements(window) function AboutPage() { return ( <Switch> <Route path="/deals" component={ App } /> </Switch> ); }
about 3 years ago · Juan Pablo Isaza Report
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