"Se um trabalhador quiser fazer bem o seu trabalho, ele deve primeiro afiar suas ferramentas." - Confúcio, "Os Analectos de Confúcio. Lu Linggong"
Primeira página > Programação > Como renderizar HTML bruto no React com segurança?

Como renderizar HTML bruto no React com segurança?

Publicado em 2024-11-08
Navegar:734

How to Render Raw HTML in React Safely?

Renderizando HTML bruto com React: uma abordagem mais segura

No React, renderizar HTML bruto pode ser uma tarefa complexa. Embora o método tradicional de usar perigosalySetInnerHTML funcionasse em versões anteriores, ele foi descontinuado devido a questões de segurança. No entanto, agora existem métodos mais seguros disponíveis.

Opções de renderização segura

Para uma renderização HTML mais segura, você tem quatro opções principais:

  1. Unicode: Salve seu arquivo como UTF-8 e defina o conjunto de caracteres como UTF-8. Use caracteres Unicode para símbolos e entidades especiais.
  2. Número Unicode: Dentro de uma string JavaScript, use o número Unicode para a entidade desejada.
  3. Matriz Mista: Combine strings e elementos JSX dentro de uma matriz para renderização.
  4. dangerouslySetInnerHTML: Como último recurso, use perigosamenteSetInnerHTML com o ódio, use uma entrada que seja direcionada aman e tepercaya.

Exemplo de uso da opção de array misto:

const markup = [
  'First ',
  ·,
  ' Second'
];

return 
{markup}
;

Conclusão

Embora a renderização de HTML bruto com React possa ser necessária em determinados cenários, é essencial priorizar a segurança. Ao utilizar os métodos mais seguros descritos acima, você pode garantir a segurança e a confiabilidade de seus aplicativos React e, ao mesmo tempo, atender aos seus requisitos de renderização.

Tutorial mais recente Mais>

Isenção de responsabilidade: Todos os recursos fornecidos são parcialmente provenientes da Internet. Se houver qualquer violação de seus direitos autorais ou outros direitos e interesses, explique os motivos detalhados e forneça prova de direitos autorais ou direitos e interesses e envie-a para o e-mail: [email protected]. Nós cuidaremos disso para você o mais rápido possível.

Copyright© 2022 湘ICP备2022001581号-3