IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)
Navigation

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les réponses en temps réel, voter pour les messages, poser vos propres questions et recevoir la newsletter

JavaScript Discussion :

onclick ne marche pas


Sujet :

JavaScript

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre habitué
    Homme Profil pro
    Inscrit en
    Mai 2011
    Messages
    10
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Mai 2011
    Messages : 10
    Par défaut onclick ne marche pas
    Bonjour, je cherche à créer une balise input avec javascript.
    J'ai essayé ceci:

    Code Javascript : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    //Creation de l'input
    var butt = document.createElement('input');
    butt.type = 'button';
    butt.value = "clique!";
    butt.onclick = "alert('clique effectué');";
     
    //Insertion de L'input dans un div 'box'
    document.getElementById('box').appendChild(butt);

    Voila je vois bien apparaitre le bouton mais dès que je clique dessus rien ne se passe

    Merci d'avance

  2. #2
    Rédacteur

    Avatar de Bovino
    Homme Profil pro
    Développeur Web
    Inscrit en
    Juin 2008
    Messages
    23 647
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 54
    Localisation : France, Gironde (Aquitaine)

    Informations professionnelles :
    Activité : Développeur Web
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Juin 2008
    Messages : 23 647
    Billets dans le blog
    20
    Par défaut
    La propriété onclick attend comme valeur une fonction de rappel, toi tu lui passes une chaine... ça risque pas de marcher
    Pas de question technique par MP !
    Tout le monde peut participer à developpez.com, vous avez une idée, contactez-moi !
    Mes formations video2brain : La formation complète sur JavaScriptJavaScript et le DOM par la pratiquePHP 5 et MySQL : les fondamentaux
    Mon livre sur jQuery
    Module Firefox / Chrome d'intégration de JSFiddle et CodePen sur le forum

  3. #3
    Membre habitué
    Homme Profil pro
    Inscrit en
    Mai 2011
    Messages
    10
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Mai 2011
    Messages : 10
    Par défaut
    J'ai essayé avec une fonction mais ça ne marche toujours pas

    Code Javascript : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    function clik() {
        alert('clique effectue!');
    }
     
    //Creation de l'input
    var butt = document.createElement('input');
    butt.type = 'button';
    butt.value = "clique!";
    butt.onclick = "clik();";
     
    //Insertion de L'input dans un div 'box'
    document.getElementById('box').appendChild(butt);

    Peut être avec onload?

  4. #4
    Membre Expert
    Avatar de Loceka
    Profil pro
    Inscrit en
    Mars 2004
    Messages
    2 276
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mars 2004
    Messages : 2 276
    Par défaut
    Ce qu'il voulait dire c'était qu'il fallait l'écrire comme ça :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    butt.onclick = function() {alert('clique effectué');};

  5. #5
    Rédacteur

    Avatar de Bovino
    Homme Profil pro
    Développeur Web
    Inscrit en
    Juin 2008
    Messages
    23 647
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 54
    Localisation : France, Gironde (Aquitaine)

    Informations professionnelles :
    Activité : Développeur Web
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Juin 2008
    Messages : 23 647
    Billets dans le blog
    20
    Par défaut
    Ou alors (si la fonction clik est définie)


    Encore une fois, il faut différencier les types.
    "clik();" est une chaine, donc lorsque tu cliques sur le bouton, ça appelle une chaine et le résultat est que rien ne se passe.
    clik(); est le résultat de l'exécution de la fonction, donc dans ce cas, tu affecterais au clic du bouton le résultat de l'exécution de cette fonction.
    click est une fonction, dans ce cas (et comme dans le cas proposé par Loceka), c'est bien l'exécution de la fonction que génèrera le clic sur le bouton.
    Pas de question technique par MP !
    Tout le monde peut participer à developpez.com, vous avez une idée, contactez-moi !
    Mes formations video2brain : La formation complète sur JavaScriptJavaScript et le DOM par la pratiquePHP 5 et MySQL : les fondamentaux
    Mon livre sur jQuery
    Module Firefox / Chrome d'intégration de JSFiddle et CodePen sur le forum

  6. #6
    Membre habitué
    Homme Profil pro
    Inscrit en
    Mai 2011
    Messages
    10
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Mai 2011
    Messages : 10
    Par défaut
    Merci beaucoup Bovino et Loceka

    ça marche du tonnerre avec un fichier html et un fichier js.
    Mais il reste un léger soucis. J'ai tenté de lancer ce script sur greasemonkey et le bouton a complètement disparu lorsque j'ai fait le changement.

    userscript:

    Code javascript : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    	// ==UserScript==
    //@name			test bouton
    //@description           bouton clique
    //@author		        Robthor
    // ==/UserScript==
     
     
    function click() {
    	alert('clique effectué');
    }
     
    //creation div et insertion dans body
    var div1 = document.createElement('div');
    div1.id='box';
    document.getElementsByTagName('body')[0].appendChild(div1);
     
    //ajout style dans l'element lediv1
    div1.style.border = '1px double maroon';
    div1.style.position = 'absolute';
    div1.style.left = '0px';
    div1.style.top = '0px';
    div1.style.backgroundColor = 'white';
     
    //Creation de l'input
    var butt = document.createElement('input');
    butt.type = 'button';
    butt.value = "clique!";
    //butt.onclick = function() {alert('clique effectué');};
    butt.onclick = click;
     
    //Insertion de L'input dans un div 'box'
    document.getElementById('box').appendChild(butt);

+ Répondre à la discussion
Cette discussion est résolue.

Discussions similaires

  1. onclick dans un append marche pas
    Par dknafoweb dans le forum Général JavaScript
    Réponses: 2
    Dernier message: 29/10/2014, 12h06
  2. onclick return false ne marche pas sur Chrome !
    Par gstratege dans le forum Général JavaScript
    Réponses: 12
    Dernier message: 21/09/2014, 21h49
  3. onclick qui ne marche pas sur un bouton
    Par sliders_alpha dans le forum Général JavaScript
    Réponses: 5
    Dernier message: 02/10/2011, 21h51
  4. Un onClick ne marche pas après un onChange.
    Par FrenchFrogger dans le forum Général JavaScript
    Réponses: 8
    Dernier message: 25/11/2010, 09h45
  5. Onclick ne marche pas sur un element "disabled"
    Par Niki59 dans le forum Général JavaScript
    Réponses: 2
    Dernier message: 09/07/2009, 13h12

Partager

Partager
  • Envoyer la discussion sur Viadeo
  • Envoyer la discussion sur Twitter
  • Envoyer la discussion sur Google
  • Envoyer la discussion sur Facebook
  • Envoyer la discussion sur Digg
  • Envoyer la discussion sur Delicious
  • Envoyer la discussion sur MySpace
  • Envoyer la discussion sur Yahoo