"Si un trabajador quiere hacer bien su trabajo, primero debe afilar sus herramientas." - Confucio, "Las Analectas de Confucio. Lu Linggong"
Página delantera > Programación > ¿Cómo representar de forma segura cadenas HTML en React usando peligrosamenteSetInnerHTML?

¿Cómo representar de forma segura cadenas HTML en React usando peligrosamenteSetInnerHTML?

Publicado el 2024-11-18
Navegar:732

How to Safely Render HTML Strings in React Using dangerouslySetInnerHTML?

Representación segura de cadenas HTML como HTML

En este escenario, el problema surge al intentar representar una cadena normal de contenido HTML, pero en cambio, aparece como una cadena sin ser interpretado como HTML. Esto suele ocurrir cuando la propiedad que se utiliza en peligrosamenteSetInnerHTML es un objeto en lugar de una cadena.

Para resolver esto, asegúrese de que la propiedad this.props.match.description sea una cadena. Si no es así, conviértalo a HTML antes de asignarlo a la propiedad.

Manejo de entidades HTML

Surgen complicaciones adicionales al tratar con entidades HTML. En tales casos, deberá decodificar las entidades antes de pasarlas a peligrosamenteSetInnerHTML.

Código de ejemplo

Considere el siguiente código de ejemplo:

class App extends React.Component {
  constructor() {
    super();
    this.state = {
      description: '

Our Opportunity:

', }; } htmlDecode(input) { const e = document.createElement('div'); e.innerHTML = input; return e.childNodes.length === 0 ? '' : e.childNodes[0].nodeValue; } render() { return (
); } } ReactDOM.render(, document.getElementById('root'));

En este ejemplo, la propiedad de descripción contiene entidades HTML (). Para representarlo correctamente, se utiliza la función htmlDecode para decodificar estas entidades antes de pasar el HTML a peligrosamenteSetInnerHTML.

Último tutorial Más>

Descargo de responsabilidad: Todos los recursos proporcionados provienen en parte de Internet. Si existe alguna infracción de sus derechos de autor u otros derechos e intereses, explique los motivos detallados y proporcione pruebas de los derechos de autor o derechos e intereses y luego envíelos al correo electrónico: [email protected]. Lo manejaremos por usted lo antes posible.

Copyright© 2022 湘ICP备2022001581号-3