Maison > interface Web > js tutoriel > Pourquoi \'Uncaught ReferenceError : la fonction n'est pas définie\' se produit-il avec les attributs Onclick et comment puis-je y remédier ?

Pourquoi \'Uncaught ReferenceError : la fonction n'est pas définie\' se produit-il avec les attributs Onclick et comment puis-je y remédier ?

Linda Hamilton
Libérer: 2024-11-27 00:16:11
original
370 Les gens l'ont consulté

Why Does

"Uncaught ReferenceError : la fonction n'est pas définie" avec l'attribut Onclick

Problème :

Lorsque vous cliquez sur un bouton avec un attribut onclick, l'erreur "Uncaught ReferenceError : la fonction n'est pas définie" se produit.

Cause :

Les scripts utilisateur s'exécutent dans un environnement isolé où onclick opère dans la portée de la page cible. Par conséquent, onclick ne peut pas accéder aux fonctions définies dans le script utilisateur.

Solution :

Évitez d'utiliser onclick et utilisez plutôt addEventListener(). Par exemple :

emoteTab[2].innerHTML += '<span>
Copier après la connexion

Code mis à jour :

for (i = 0; i < EmoteURLLines.length; i++) {
    if (checkIMG (EmoteURLLines[i])) {
        localStorage.setItem ("nameEmotes", JSON.stringify (EmoteNameLines));
        localStorage.setItem ("urlEmotes", JSON.stringify (EmoteURLLines));
        localStorage.setItem ("usageEmotes", JSON.stringify (EmoteUsageLines));
        if (i == 0) {
            console.log (resetSlot ());
        }
        emoteTab[2].innerHTML  += '<span>
Copier après la connexion
var targetSpans = emoteTab[2].querySelectorAll ("span[data-usage]");
for (var J in targetSpans) {
    targetSpans[J].addEventListener ("click", appendEmote, false);
}
Copier après la connexion

Avertissements supplémentaires :

  • Évitez d'utiliser le même identifiant pour plusieurs éléments (invalide).
  • N'oubliez pas que l'utilisation innerHTML ou externalHTML peuvent écraser les gestionnaires d'événements sur les nœuds concernés.

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!

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