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 :

Gerer le ctrl + S en javascript


Sujet :

JavaScript

  1. #21
    Membre actif
    Inscrit en
    Octobre 2010
    Messages
    59
    Détails du profil
    Informations forums :
    Inscription : Octobre 2010
    Messages : 59
    Par défaut
    Effectivement, ceici marche tres bien quand on a le focus :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    document.onkeydown = function(e)
    						{
    							if(e.ctrlKey && e.keyCode==83)
    							{
    								(navigator.appName.substring(0,3)=="Mic") ? event.returnValue = false : e.preventDefault();
    								$('newThird').innerHTML = 'Envoie du formulaire';
    							}
    						}

  2. #22
    Membre actif
    Inscrit en
    Octobre 2010
    Messages
    59
    Détails du profil
    Informations forums :
    Inscription : Octobre 2010
    Messages : 59
    Par défaut
    est ce que quelqu'un serai comment déclencher l'appuie sur un bouton summit en javascript ?

    Car après mon ctrl + s, je voudrais que sa envoie un formulaire ^^ !

  3. #23
    Rédacteur/Modérateur

    Avatar de SpaceFrog
    Homme Profil pro
    Développeur Web Php Mysql Html Javascript CSS Apache - Intégrateur - Bidouilleur SharePoint
    Inscrit en
    Mars 2002
    Messages
    39 658
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 75
    Localisation : Royaume-Uni

    Informations professionnelles :
    Activité : Développeur Web Php Mysql Html Javascript CSS Apache - Intégrateur - Bidouilleur SharePoint
    Secteur : Industrie

    Informations forums :
    Inscription : Mars 2002
    Messages : 39 658
    Billets dans le blog
    1
    Par défaut
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    document.forms[0].submit()
    Ma page Developpez - Mon Blog Developpez
    Président du CCMPTP (Comité Contre le Mot "Problème" dans les Titres de Posts)
    Deux règles du succès: 1) Ne communiquez jamais à quelqu'un tout votre savoir...
    Votre post est résolu ? Alors n'oubliez pas le Tag

    Venez sur le Chat de Développez !

  4. #24
    Membre actif
    Inscrit en
    Octobre 2010
    Messages
    59
    Détails du profil
    Informations forums :
    Inscription : Octobre 2010
    Messages : 59
    Par défaut
    Citation Envoyé par SpaceFrog Voir le message
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    document.forms[0].submit()
    C'est tellement évidant x) merci beaucoup

  5. #25
    Membre actif
    Inscrit en
    Octobre 2010
    Messages
    59
    Détails du profil
    Informations forums :
    Inscription : Octobre 2010
    Messages : 59
    Par défaut
    Rebonjour tout le monde,

    le code que vous m'avez donné marche très bien, mais malheureusement ne marche qu'une seul fois :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    document.onkeydown = function(e){
    	if(e.ctrlKey && e.keyCode==83){
    	(navigator.appName.substring(0,3)=="Mic") ? event.returnValue = false : e.preventDefault();
    		// Ta fonction
    	}
    Comment pourrais je faire pour qu'il marche autant de fois que je veux ?

  6. #26
    Membre actif
    Inscrit en
    Octobre 2010
    Messages
    59
    Détails du profil
    Informations forums :
    Inscription : Octobre 2010
    Messages : 59
    Par défaut
    Personne n'a de solution ? je ne comprend pas pourquoi sa ne marche qu'une seul fois oO

  7. #27
    Membre chevronné Avatar de nadox
    Homme Profil pro
    Développeur
    Inscrit en
    Février 2010
    Messages
    360
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Calvados (Basse Normandie)

    Informations professionnelles :
    Activité : Développeur
    Secteur : High Tech - Multimédia et Internet

    Informations forums :
    Inscription : Février 2010
    Messages : 360
    Par défaut
    Bonsoir, quel est le code utilisé exactement ? Si tu envoie un formulaire, la page est rechargée...

  8. #28
    Expert confirmé
    Avatar de Watilin
    Homme Profil pro
    En recherche d'emploi
    Inscrit en
    Juin 2010
    Messages
    3 094
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 36
    Localisation : France, Ille et Vilaine (Bretagne)

    Informations professionnelles :
    Activité : En recherche d'emploi

    Informations forums :
    Inscription : Juin 2010
    Messages : 3 094
    Par défaut
    Dites les gars, je dois être complètement à l'ouest parce qu'aucune des solutions données ne marche chez moi. Je peux ajouter un comportement sur Ctrl + S, mais pas remplacer le comportement par défaut… De plus, sous Gmail et Google Docs, j'ai la même fenêtre qu'ailleurs, donc je ne vois pas de quoi vous parlez.
    Mon navigateur est Firefox 3.6, et j'ai vérifié 15 fois…
    La FAQ JavaScript – Les cours JavaScript
    Touche F12 = la console → l’outil indispensable pour développer en JavaScript !

  9. #29
    Membre actif
    Inscrit en
    Octobre 2010
    Messages
    59
    Détails du profil
    Informations forums :
    Inscription : Octobre 2010
    Messages : 59
    Par défaut
    En fait, tu écris des truc dans un textarea --> donc tu a le focus sur la page
    Après tu fais ton ctrl + s et le code fonctionne

    A l’intérieur tu met se que tu veux, j'ai mis un envoie de formulaire --> OK, sa recharge la page

    Mais pour ma deuxième utilisation, la fonction du ctrl + s apuie sur un boutons qui envoie un ajax.request (sa ne recharge pas la page), lors du 2eme ctrl + s, sa ne marche plus !!! En fait c'est un bloc note que j'ai creer, vous pouvez test ici : http://hayj.free.fr

  10. #30
    Membre actif
    Inscrit en
    Octobre 2010
    Messages
    59
    Détails du profil
    Informations forums :
    Inscription : Octobre 2010
    Messages : 59
    Par défaut
    Peu être qu'il faut supprimé le onkeydown et le recréer ?

  11. #31
    Membre chevronné Avatar de nadox
    Homme Profil pro
    Développeur
    Inscrit en
    Février 2010
    Messages
    360
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Calvados (Basse Normandie)

    Informations professionnelles :
    Activité : Développeur
    Secteur : High Tech - Multimédia et Internet

    Informations forums :
    Inscription : Février 2010
    Messages : 360
    Par défaut
    Code : 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
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    45
    46
     
    <!-----------BLOC NOTE------------->
    <form style="position: absolute; width: 339px; right: 0;" id="formulaireCSS3">
    	<label style="font-size: 15px; top: -7px; left: 130px;" for="textarea">Bloc-note :</label>
    	<textarea id="textarea" name="textarea" cols="40" rows="40"></textarea>
    	<div id="chargement"><input id="saveBloc" style="position: relative; top : -5px; left: 138px; margin: 3px;" type="submit" value="save" onclick="editBlocnote();"/></div>
    </form>
    <script>
    	//On l'edit :
    	function editBlocnote()
    	{
    		$('chargement').innerHTML = '<img style="position: relative; top : -5px; left: 154px; margin-bottom: 1px;" src="images/chargement.gif"/>';
    		var params = 'text=' + $('textarea').value;
    		new Ajax.Request
    		(
    			"editBlocnote.php",
    			{
    				method: 'post',
    				parameters: params,
    				onComplete: function(transport)
    				{
    					setTimeout("updateButton()", 500);
    				}
    			}
    		);
    	}
     
    	function updateButton()
    	{
    		$('chargement').innerHTML = '<input style="position: relative; top : -5px; left: 138px; margin: 3px;" type="button"value="save" id="createNew" onclick="editBlocnote();"/>';
    	}
     
    	createOnkeydown();
    	function createOnkeydown()
    	{
    		document.onkeydown = function(e)
    		{
    			if(e.ctrlKey && e.keyCode==83 && $('saveBloc') != null)
    			{
    				(navigator.appName.substring(0,3)=="Mic") ? event.returnValue = false : e.preventDefault();
    				$('saveBloc').click();
    			}
    		}
    	}
    </script>
    <!-----------------------------------></div>
    Tu utilise un input type subit que tu enlevé lorsque tu poste via Ajax, puis tu en recréé un autre de type button lorsque l'ajax revient... Mais surtout : ton input de type button n'as plus d'id ?!
    De plus, il n'est pas très conseillé d'utiliser la méthode click...

    Tu devrais n'utiliser qu'un input de type button, ne pas le supprimer mais plutôt le masquer, et sur le ctrl + s, pourquoi ne pas appeler simplement la fonction editBlocnote ?

  12. #32
    Membre actif
    Inscrit en
    Octobre 2010
    Messages
    59
    Détails du profil
    Informations forums :
    Inscription : Octobre 2010
    Messages : 59
    Par défaut
    Wahouuu je me rend compte de toutes mes erreur
    Tu a raison, c'est pas le ctrl+ s qui ne marche pas, c'est juste que je remet pas le même id !
    De plus j'ai pas besoin de faire mon .click(), il faut juste rappelé la fonction

    Par contre je ne peux pas caché mon input parce que je le remplace par une image et apres je le remet !!!

    Merci beaucoup de m'avoir aider (je pensais vraiment que c'était le ctrl + s qui ne marchait qu'une fois...), je met tout de suite le topic en résolu

  13. #33
    Membre chevronné Avatar de nadox
    Homme Profil pro
    Développeur
    Inscrit en
    Février 2010
    Messages
    360
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Calvados (Basse Normandie)

    Informations professionnelles :
    Activité : Développeur
    Secteur : High Tech - Multimédia et Internet

    Informations forums :
    Inscription : Février 2010
    Messages : 360
    Par défaut
    Si si tu peux masquer l'input plutôt que le supprimer et afficher l'image avant la requête Ajax. Puis, lors du retour de l'ajax, tu masque l'image et tu réaffiche l'input... C'est un simple jeu de style css avec la propriété display !

  14. #34
    Membre actif
    Inscrit en
    Octobre 2010
    Messages
    59
    Détails du profil
    Informations forums :
    Inscription : Octobre 2010
    Messages : 59
    Par défaut
    Citation Envoyé par nadox Voir le message
    Si si tu peux masquer l'input plutôt que le supprimer et afficher l'image avant la requête Ajax. Puis, lors du retour de l'ajax, tu masque l'image et tu réaffiche l'input... C'est un simple jeu de style css avec la propriété display !
    Ouep ok jvais faire ça rien que pour te faire plaisir <3

  15. #35
    Membre actif
    Inscrit en
    Octobre 2010
    Messages
    59
    Détails du profil
    Informations forums :
    Inscription : Octobre 2010
    Messages : 59
    Par défaut
    Voilà c'est fait ^^

    Code : 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
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    45
    46
    47
    48
    49
    50
    51
    52
    53
    54
    55
    56
    57
    58
    59
    60
    61
    62
    63
    64
    65
    66
    67
    68
    <!-----------BLOC NOTE------------->
    <form style="position: absolute; width: 339px; right: 0;" id="formulaireCSS3">
    	<label style="font-size: 15px; top: -7px; left: 130px;" for="textarea">Bloc-note :</label>
    	<textarea id="textarea" name="textarea" cols="40" rows="40"><?php
                            if(!($fp = fopen("private/blocnote.txt","r")))
                            {
                                    echo "Echec de l'ouverture du fichier";
                                    exit;
                            }
                            while(!feof($fp))
                            {
                                    // On récupère une ligne
                                    $ligne = fgets($fp,255);
                                    // On affiche la ligne
                                    echo $ligne;
                            }
                            fclose($fp); // On ferme le fichier
                    ?></textarea>
    	<div id="chargement">
    		<input style="position: relative; top : -5px; left: 138px; margin: 3px;" type="button" value="save" id="createNew" onclick="editBlocnote();"/>
    		<img id="imgChargement" style="position: relative; top : -5px; left: 154px; margin-bottom: 1px; display: none;" src="images/chargement.gif"/>
    	</div>
     
    </form>
    <script>
    	//On l'edit :
    	function editBlocnote()
    	{
    		//$('chargement').innerHTML = '<img style="position: relative; top : -5px; left: 154px; margin-bottom: 1px;" src="images/chargement.gif"/>';
    		$('createNew').style.display = "none";
    		//$$('#chargement > img').style.display = "block"; //ne fonctionne pas oO
    		$('imgChargement').style.display = "block";
    		var params = 'text=' + $('textarea').value;
    		new Ajax.Request
    		(
    			"request/editBlocnote.php",
    			{
    				method: 'post',
    				parameters: params,
    				onComplete: function(transport)
    				{
    					setTimeout("updateButton()", 500);
    				}
    			}
    		);
    	}
     
    	function updateButton()
    	{
    		//$('chargement').innerHTML = '<input style="position: relative; top : -5px; left: 138px; margin: 3px;" type="button" value="save" id="createNew" onclick="editBlocnote();"/>';
    		$('imgChargement').style.display = "none";
    		$('createNew').style.display = "block";
    	}
     
    	createOnkeydown();
    	function createOnkeydown()
    	{
    		document.onkeydown = function(e)
    		{
    			if(e.ctrlKey && e.keyCode==83 && $('createNew') != null)
    			{
    				(navigator.appName.substring(0,3)=="Mic") ? event.returnValue = false : e.preventDefault();
    				editBlocnote();
    			}
    		}
    	}
    </script>
    <!----------------------------------->

+ Répondre à la discussion
Cette discussion est résolue.
Page 2 sur 2 PremièrePremière 12

Discussions similaires

  1. Gerer message d'erreur avec javascript et struts
    Par phpaide dans le forum Struts 1
    Réponses: 1
    Dernier message: 22/01/2009, 16h12
  2. Réponses: 1
    Dernier message: 04/06/2008, 17h00
  3. Généré un Ctrl-F à partir de Javascript
    Par vsevel dans le forum Général JavaScript
    Réponses: 1
    Dernier message: 10/05/2007, 18h44
  4. Comment gérer les objects déclarer en HTML dans un script JAVASCRIPT?
    Par Thauglor dans le forum Général JavaScript
    Réponses: 3
    Dernier message: 25/04/2006, 14h54
  5. [Javascript] Gerer impression automatique de document
    Par amarcil dans le forum Général JavaScript
    Réponses: 3
    Dernier message: 28/02/2006, 15h08

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