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 :

document.createTextNode / Copier du texte dans une DIV éditable et retour à la ligne.


Sujet :

JavaScript

  1. #1
    Membre actif
    Profil pro
    Inscrit en
    Mai 2004
    Messages
    551
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mai 2004
    Messages : 551
    Points : 264
    Points
    264
    Par défaut document.createTextNode / Copier du texte dans une DIV éditable et retour à la ligne.
    Bonjour,

    J'utilise ce code pour insérer dans une DIV éditable du texte au niveau du curseur et se trouvant dans le textarea 'AreaInsert':

    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
     
    function insertAtCursor(){
        get('myInstance1').focus() ; // DIV avec le curseur 'myInstance1' (Editable DIV)
        var sel, range, html;
        var text = get('AreaInsert').value ; // Textarea avec le texte à insérer dans la DIV myInstance1
     
        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) { // Pour Internet Explorer
            document.selection.createRange().text = text;
        }
    }
    Ce code insère bien le contenu de AreaInsert dans myInstance1. Le problème c'est les retours à la ligne.
    Dans le cas d'Internet Explorer qui utilise ce code document.selection.createRange().text = text; les retours à la ligne sont bien respectés.

    Pour les autres navigateurs utilisant range.insertNode cela ne respecte pas les retours à la ligne et tout ce qui est inséré dans la div se tient sur la même ligne.

    J'ai essayé de régler le problème comme ceci:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     var br = document.createElement('br');
        text = text.replace(/\\n/g, br);
    Mais cela insére dans la DIV éditable myInstance1 [object HTMLBRElement] à la place d'un retour à la ligne.

    Comment Copier le contenu du textarea dans la div en respectant les retours à la ligne ?

    Je pensais couper le contenu du textarea dans un tableau pour séparer chaque ligne mais je ne vois pas comment faire. Et faire autant de range.insertNode qu'il y a d’éléments dans le tableau en les séparant avec document.createElement('br');

    Merci.

  2. #2
    Membre actif
    Profil pro
    Inscrit en
    Mai 2004
    Messages
    551
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mai 2004
    Messages : 551
    Points : 264
    Points
    264
    Par défaut
    Voilà le code (Pas fait par moi ) mais reprenant l'idée du split du textarea:
    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
     
    function insertAtCursor(){
        document.getElementById('myInstance1').focus() ; // DIV with cursor is 'myInstance1' (Editable DIV)
        var sel, range;
        var text = document.getElementById('AreaInsert').value ; // Textarea containing the text to add to the myInstance1 DIV
        if (window.getSelection) {
            sel = window.getSelection();
            if (sel.getRangeAt && sel.rangeCount) {
                range = sel.getRangeAt(0);
                range.deleteContents();
     
                var lines = text.replace('\\r\\n', '\\n').split('\\n');
                var frag = document.createDocumentFragment();
                for (var i = 0, len = lines.length; i < len; ++i) {
                    if (i > 0) {
                        frag.appendChild( document.createElement("br") );
                    }
                    frag.appendChild( document.createTextNode(lines[i]) );
                }
     
                range.insertNode(frag);
            }
        } else if (document.selection && document.selection.createRange) {
            document.selection.createRange().text = text;
        }
    }

  3. #3
    Modérateur

    Avatar de NoSmoking
    Homme Profil pro
    Inscrit en
    Janvier 2011
    Messages
    17 075
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Isère (Rhône Alpes)

    Informations forums :
    Inscription : Janvier 2011
    Messages : 17 075
    Points : 44 657
    Points
    44 657
    Par défaut
    Bonjour,
    vu que tu passes par des document.createTextNode, n'aurais tu pas meilleur compte de faire un
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    var result = lines.join('<br>');
    frag.innerHTML = result;

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

Discussions similaires

  1. Probleme affichage de texte dans une Div.
    Par philsand77 dans le forum Balisage (X)HTML et validation W3C
    Réponses: 5
    Dernier message: 10/02/2009, 15h19
  2. [JQuery] Du texte dans une div lors du clique sur un lien
    Par Nimothenicefish dans le forum jQuery
    Réponses: 5
    Dernier message: 28/11/2008, 15h33
  3. depassement du texte dans une div sous FF
    Par Devilju69 dans le forum Mise en page CSS
    Réponses: 1
    Dernier message: 06/10/2008, 14h34
  4. remplacer texte dans une div ou span ?
    Par guix77 dans le forum Général JavaScript
    Réponses: 3
    Dernier message: 14/04/2006, 11h19
  5. Introduire du text dans une div
    Par 10-nice dans le forum Général JavaScript
    Réponses: 2
    Dernier message: 01/09/2005, 11h50

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