Erreur evenement
ThomasCanal
-
ThomasCanal -
ThomasCanal -
Bonjour,
Dans mon application je souhaite supprimer tout ce qui se trouve dans le body lorsque l'utilisateur appuie sur un certain élément. J'ai donc lié cet élément à un evenement contenant la fonction de suppression, sauf que la fonction s’exécute sans l'appuie sur l’élément, et donc le body est supprimé dès le début et rien ne s'affiche :
Dans mon application je souhaite supprimer tout ce qui se trouve dans le body lorsque l'utilisateur appuie sur un certain élément. J'ai donc lié cet élément à un evenement contenant la fonction de suppression, sauf que la fonction s’exécute sans l'appuie sur l’élément, et donc le body est supprimé dès le début et rien ne s'affiche :
<code><code></code></code>
<html>
<head>
</head>
<body>
<script>
function Element(type, texte){
this.type = type;
this.texte = texte;
}
function Creation(elemtab)
{
var nvelem;
var texte;
var ul;
for(i=0;i<elemtab.length;i++)
{
if(elemtab[i].type=="ul")
{
ul = document.createElement(elemtab[i].type);
document.body.appendChild(ul);
}
else if(elemtab[i].type=="li")
{
nvelem = document.createElement(elemtab[i].type);
texte = document.createTextNode(elemtab[i].texte);
nvelem.appendChild(texte);
ul.appendChild(nvelem);
}
else
{
nvelem = document.createElement(elemtab[i].type);
texte = document.createTextNode(elemtab[i].texte);
nvelem.appendChild(texte);
document.body.appendChild(nvelem);
}
}
}
function suppression(){
var body = document.body;
while(body.childNodes[0])
{
body.removeChild(body.childNodes[0]);
}
}
var li = document.querySelector('ul');
for(i=0;i<li.childNodes.length;i++)
{
li.childNodes[i].addEventListener('click',suppression());
}
var elemtab = [new Element('h1', 'Menu Principal'),new Element('ul',''),new Element('li', 'Commencer l\'exercice'),new Element('li', 'Voir le tableau des résultats'),new Element('li', 'Quitter l\'application')];
Creation(elemtab);
</script>
</body>
</html>
A voir également:
- Erreur evenement
- Erreur 0x80070643 - Accueil - Windows
- Erreur 4201 france tv ✓ - Forum Réseaux sociaux
- J'aime par erreur facebook notification - Forum Facebook
- Iptv erreur de lecture - Forum TV & Vidéo
- Code erreur f3500-31 ✓ - Forum Bbox Bouygues
3 réponses
Bonjour,
Ne mets pas les parenthèses
li.childNodes[i].addEventListener('click',suppression());
Ne mets pas les parenthèses
li.childNodes[i].addEventListener('click',suppression);
bon il y a plus simple et plus élégant mais ça devrais vous donner des idées:
Bien sûr on peut très bien ajouter une condition pour que le paramètre contenu puisse aussi ajouter un HTMLElement dans un autre(au lieu de seulement du texte), ce qui peut être pratique.
<!doctype html> <html> <head> <style type="text/css" rel="stylesheet"> span{background-color:#fac0c0;} </style> </head> <body> <script> document.body.onload = function(){//-- pour être sûr function videLaPage(){ document.body.innerHTML='';//-- c'est plus joli avec remove mais plus long à écrire } function ajoutContenu( tag, contenu , cible ){ var tmp = document.createElement(tag); if(tmp.constructor.name != 'HTMLUnknownElement'){//-- vérifie que tag est un élement valide cible.appendChild(tmp); if(typeof contenu === typeof ''){//-- le contenu est du texte tmp.appendChild( document.createTextNode(contenu) ); } return tmp; } console.log('mauvais nom de balise: '+tag); return; } ajoutContenu('p', 'du texte', document.body); ajoutContenu('c',' pas bon' , document.body); ajoutContenu('span', ' *un sous-texte dans le premier \'p\'* CLIQUER POUR VIDER ', document.getElementsByTagName('p')[0]).addEventListener( 'click', videLaPage ); } </script> <body>
Bien sûr on peut très bien ajouter une condition pour que le paramètre contenu puisse aussi ajouter un HTMLElement dans un autre(au lieu de seulement du texte), ce qui peut être pratique.
il est bien compliqué ce script, pas évident de voir l'erreur.
Déjà
Je fait quelque chose d'un peu plus fonctionnel et je le propose bientôt.
Suite à la suppression du body j'essaye de créer du code html avec un fichier avascript externe, j'integre donc une balise <script> et j'y ajoute la source de mon fichier. Mais quand je teste rien ne s'affiche, sauriez vous pourquoi ?
Bien sûr si le script est dans body et que vous l'enlevez c'est sûr que ça marchera pas. D'où l'intérêt d'ailleurs de ne pas tout effacer mais de changer que ce qui doit changer en gardant le body sinon autant mettre un lien vers une nouvelle page ça sera mieux.
Sans voir le code de toute façon impossible à dire mais la syntaxe est ceci: