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 :

position/ajout cursor dans un contenteditable


Sujet :

JavaScript

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre confirmé
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Avril 2009
    Messages
    76
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

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

    Informations forums :
    Inscription : Avril 2009
    Messages : 76
    Par défaut position/ajout cursor dans un contenteditable
    Bonjour,

    Voilà pour un projet personnel, j'aurais besoin de faire un truc mais impossible d'y arriver et j'ai beau parcourir le net impossible de trouver une réponse convenable :/

    Donc j'essaye en faite dans une balise "code" avec le paramètre contenteditable de rajouter un "tab" à la position du curseur.

    La personne appuie sur "tab" cela rajoute une tabulation et déplace le cursor après la tabulation.

    Pour l'instant je n'arrive qu'à rajouter une tabulation mais je me prend la tête avec ce focus >_<

    Voilà mon code pour add du texte déjà

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    function insertTextAtCursor(text) {
    			    var sel, range, html;
    			    if (window.getSelection) {
    			        sel = window.getSelection();
    			        if (sel.getRangeAt && sel.rangeCount) {
    			            range = sel.getRangeAt(0);
    			            range.deleteContents();
    			            range.insertNode(document.createTextNode(text));
    			        }
    			    } else if (document.selection && document.selection.createRange) {
    			        document.selection.createRange().text = text;
    			    }
    			}
    Merci de votre aide !!

  2. #2
    Rédacteur/Modérateur

    Avatar de SylvainPV
    Profil pro
    Inscrit en
    Novembre 2012
    Messages
    3 375
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Novembre 2012
    Messages : 3 375
    Par défaut
    La touche Tabulation sert à basculer d'élément en élément pour la navigation au clavier. A voir si tu tiens vraiment à sacrifier cette base d'ergonomie. Si c'est le cas, il faudrait essayer de bloquer la propagation de l'évènement, avec un event.preventDefault() dans ton onkeydown/up par exemple.

    Peux-tu nous montrer le code du binding évènement ?

  3. #3
    Membre confirmé
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Avril 2009
    Messages
    76
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

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

    Informations forums :
    Inscription : Avril 2009
    Messages : 76
    Par défaut
    Oui pour ce que je desire faire c'est necessaire

    Pour l'instant je fais juste :

    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
     
      $('code').keydown(function(e) {
        var keycode   = (e.keyCode ? e.keyCode : e.which);
        if (keycode == 9){
    	insertTextAtCursor("\t");
    	return false;
        } 
      });
     
      function insertTextAtCursor(text) {
        var sel, range, html;
        if (window.getSelection) {
            sel = window.getSelection();
            if (sel.getRangeAt && sel.rangeCount) {
                range = sel.getRangeAt(0);
                range.deleteContents();
                range.insertNode(document.createTextNode(text));
            }
        } else if (document.selection && document.selection.createRange) {
            document.selection.createRange().text = text;
        }
      }
    Ca fonctionne mais pas ce foutu focus() :o)

  4. #4
    Rédacteur/Modérateur

    Avatar de SylvainPV
    Profil pro
    Inscrit en
    Novembre 2012
    Messages
    3 375
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Novembre 2012
    Messages : 3 375
    Par défaut
    Essaie ceci :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
     
     if (keycode == 9){
        insertTextAtCursor("\t");
        e.preventDefault();
        e.stopPropagation();
        return false;
    }

  5. #5
    Membre confirmé
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Avril 2009
    Messages
    76
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

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

    Informations forums :
    Inscription : Avril 2009
    Messages : 76
    Par défaut
    Pas mieux :/

    Ca me mets mon curseur avant le tab en faite le probleme c'est qu'il faudrais qu'il se mette après.

    J'ai tenter avec deux fonctions (getCursorPosition et setCursorPosition) que j'ai trouver sur le net mais rien de braillant.

  6. #6
    Membre confirmé
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Avril 2009
    Messages
    76
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

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

    Informations forums :
    Inscription : Avril 2009
    Messages : 76
    Par défaut
    J'ai trouvé également un plugin jquery "a-tools" http://www.ampparit.com/projects/a-tools/demo.html
    qui réalise en partie ce que je veux faire mais il ne marche pas sur des balises avec contenteditable seulement avec un textearea >_<

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

Discussions similaires

  1. [Dojo] Ajouter nouveau item au position avant dernier dans tree(dojo 1.4)
    Par devkaty dans le forum Bibliothèques & Frameworks
    Réponses: 3
    Dernier message: 22/03/2010, 10h02
  2. [debutant] ajouter ImageIcon dans un Jbutton
    Par agugu dans le forum Composants
    Réponses: 4
    Dernier message: 25/04/2004, 22h40
  3. Obtenir la position du curseur dans une Image
    Par bastoune dans le forum Composants VCL
    Réponses: 6
    Dernier message: 14/11/2003, 21h02
  4. Position du curseur dans un TMemo
    Par yokito dans le forum Composants VCL
    Réponses: 3
    Dernier message: 28/08/2003, 16h35
  5. Position du curseur dans Edit
    Par MrJéjé dans le forum C++Builder
    Réponses: 3
    Dernier message: 20/06/2002, 17h09

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