Maison > interface Web > js tutoriel > Comment puis-je décoder de manière fiable les entités spéciales HTML en JavaScript ?

Comment puis-je décoder de manière fiable les entités spéciales HTML en JavaScript ?

Barbara Streisand
Libérer: 2024-12-04 11:06:12
original
617 Les gens l'ont consulté

How Can I Reliably Decode HTML Special Entities in JavaScript?

Décoder les entités HTML spéciales en toute confiance

Lors de l'analyse des réponses JSON, vous pouvez rencontrer des chaînes avec des entités HTML spéciales codées telles que "' " pour les apostrophes. Bien que « decodeHtml » de jQuery offre une solution simple, elle semble inadéquate. Explorons une approche plus robuste.

La méthode préférée consiste à utiliser un élément textarea :

function decodeHtml(html) {
    var txt = document.createElement("textarea");
    txt.innerHTML = html;
    return txt.value;
}
Copier après la connexion

Cette technique décode efficacement les entités HTML tout en préservant les balises. Pour démontrer :

Entrée :

Entity:&amp;nbsp;Bad attempt at XSS:<script>alert('new\nline?')</script><br>
Copier après la connexion

Sortie :

Entity: Bad attempt at XSS:<script>alert('new\nline?')</script><br>
Copier après la connexion

Les espaces, les nouvelles lignes et les balises dans les balises de script sont conservées avec précision. Cette approche garantit un décodage fiable des entités HTML, ce qui en fait la « bonne » solution pour votre tâche.

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

source:php.cn
Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn
Derniers articles par auteur
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal