web-dev-qa-db-fra.com

Existe-t-il une fonction permettant de désélectionner tout le texte à l'aide de JavaScript?

Existe-t-il une fonction en javascript permettant de désélectionner tout le texte sélectionné? Je suppose que cela doit être une fonction globale simple comme document.body.deselectAll(); ou quelque chose.

73
NoodleOfDeath

Essaye ça:

function clearSelection()
{
 if (window.getSelection) {window.getSelection().removeAllRanges();}
 else if (document.selection) {document.selection.empty();}
}

Cela effacera une sélection de contenu HTML normal dans n'importe quel navigateur principal. Cela n'effacera pas une sélection dans une entrée de texte ou <textarea> dans Firefox.

120
Ankur

Voici une version qui effacera toute sélection, y compris dans les entrées de texte et textareas:

Démo: http://jsfiddle.net/SLQpM/23/

function clearSelection() {
    var sel;
    if ( (sel = document.selection) && sel.empty ) {
        sel.empty();
    } else {
        if (window.getSelection) {
            window.getSelection().removeAllRanges();
        }
        var activeEl = document.activeElement;
        if (activeEl) {
            var tagName = activeEl.nodeName.toLowerCase();
            if ( tagName == "textarea" ||
                    (tagName == "input" && activeEl.type == "text") ) {
                // Collapse the selection to the end
                activeEl.selectionStart = activeEl.selectionEnd;
            }
        }
    }
}
25
Tim Down

Pour Internet Explorer, vous pouvez utiliser la méthode empty de l’objet document.selection:

document.selection.empty ();

Pour une solution inter-navigateur, voir cette réponse:

Effacer une sélection dans Firefox

6
Luke Girvin

Pour un élément textarea avec au moins 10 caractères, les éléments suivants effectueront une petite sélection puis, après une seconde et demie, le désélectionneront:

var t = document.getElementById('textarea_element');
t.focus();
t.selectionStart = 4;
t.selectionEnd = 8;

setTimeout(function()
{
 t.selectionStart = 4;
 t.selectionEnd = 4;
},1500);
0
John