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

jQuery Discussion :

[jquery2.02] mini wysiwig pour s'entrainer


Sujet :

jQuery

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre éprouvé

    Profil pro
    Inscrit en
    Août 2008
    Messages
    1 222
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Août 2008
    Messages : 1 222
    Par défaut [jquery2.02] mini wysiwig pour s'entrainer
    Bonjour, j' aimerais avec jquery concevoir un petit wysiwig.
    pour commencer j'aimerais faire quelque chose de simple

    Code html : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    <div id="menu">
    	<span>H1</span>
    </div>
    <textarea id="editer">
     
    </textarea>

    Quel serait la bonne façon de procéder pour écrire un texte dans le textarea , de sélectionner se texte et de mettre des balises avant et après ce texte ?

    Quelle est la méthode de jquery pour récupérer ce que l'on a surligner ?

    merci d'avance pour la réponse

  2. #2
    Rédacteur

    Avatar de danielhagnoul
    Homme Profil pro
    Étudiant perpétuel
    Inscrit en
    Février 2009
    Messages
    6 389
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 75
    Localisation : Belgique

    Informations professionnelles :
    Activité : Étudiant perpétuel
    Secteur : Enseignement

    Informations forums :
    Inscription : Février 2009
    Messages : 6 389
    Billets dans le blog
    125
    Par défaut
    Bonsoir

    Il y a déjà de nombreux plugins existants.

    Textarea : le code de mon plugin dvjhBBCodeTextarea vous aidera peut-être à démarrer.

    HTML5 : il serait peut-être plus intéressant de démarrer le projet sur une division éditable. Exemple d'utilisation d'une division modifiable : http://www.developpez.net/forums/d12...sion-editable/

    Blog

    Sans l'analyse et la conception, la programmation est l'art d'ajouter des bogues à un fichier texte vide.
    (Louis Srygley : Without requirements or design, programming is the art of adding bugs to an empty text file.)

  3. #3
    Membre éprouvé

    Profil pro
    Inscrit en
    Août 2008
    Messages
    1 222
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Août 2008
    Messages : 1 222
    Par défaut
    Merci de ta réponse ;

    ça m'est encore trop brutal pour le code, je voulais commencer par quelque chose de plus
    simple possible ,

    j'ai pris cette fonction
    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
     
    function insertTag(startTag, endTag, textareaId, tagType) {
        var field  = document.getElementById(textareaId);
        var scroll = field.scrollTop;
        field.focus();
     
        if (window.ActiveXObject) { // C'est IE
            var textRange = document.selection.createRange();           
            var currentSelection = textRange.text;
     
            textRange.text = startTag + currentSelection + endTag;
            textRange.moveStart("character", -endTag.length - currentSelection.length);
            textRange.moveEnd("character", -endTag.length);
            textRange.select();    
        } else { // Ce n'est pas IE
            var startSelection   = field.value.substring(0, field.selectionStart);
            alert(startSelection);
            var currentSelection = field.value.substring(field.selectionStart, field.selectionEnd);
            var endSelection     = field.value.substring(field.selectionEnd);
     
            field.value = startSelection + startTag + currentSelection + endTag + endSelection;
            field.focus();
            field.setSelectionRange(startSelection.length + startTag.length, startSelection.length + startTag.length + currentSelection.length);
        }
     
        field.scrollTop = scroll; // et on redéfinit le scroll.
    }
    le code html
    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
     
    <!doctype html>
    <html lang="fr">
        <head>
            <script src="../info/jq/js/jquery.js"></script>
                    <script src="wysi.js"></script>
            <style>
                div{color:red}
            </style>
            <script>
                function afficheHtml()
                {
                    txtBB = document.getElementById("textarea").value;
                    document.getElementById("afficheHTML").innerHTML=txtBB;
                }
                </script>
        </head>
        <body>
     
    <form  method="post">
        <div>
            <p>
                <input type="button" value="G" onclick="insertTag('<b>','</b>','textarea');" />
            </p>
        </div>
     
        <textarea id="textarea" cols="150" rows="10"></textarea>
     
        <div id="previewDiv"></div>
     
        <p>
            <input type="button" value="Visualiser" onclick="alert(afficheHtml())" />
        </p>
     
        <div id="viewDiv"></div>
    </form>
            <div id="afficheHTML">
     
            </div>
        </body>  
    </html>
    ici comment faire pour faire en sorte de travailler uniquement et directement sur le textarea ?
    que le visiteur ne voit pas les bbcodes ? pour que cela soit plus ergnomique ?

Discussions similaires

  1. Un éditeur Html Wysiwig pour Lenny ?
    Par Thrystan dans le forum Debian
    Réponses: 7
    Dernier message: 22/10/2007, 20h15
  2. [Mail] Infos minis à fournir pour ne pas être considéré spammeur
    Par Christophe Charron dans le forum Langage
    Réponses: 2
    Dernier message: 02/10/2007, 12h10
  3. [VS2005] Mini PaintBrush pour C#?
    Par Iván Y. dans le forum Visual Studio
    Réponses: 6
    Dernier message: 08/01/2007, 11h20

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