Как получить выделенную текстовую позицию из текстовой области в JavaScript?


20

Я хочу, чтобы получить выделенную позицию текста с помощью JavaScript. Например, у
меня есть простая текстовая область.

#input-text {
  resize: none;
  width: 50%;
  height: 50px;
  margin: 1rem auto;
}
<textarea id="input-text">I am a student and I want to become a good person</textarea>

В моей текстовой области у меня есть текст, такой как:

"I am a student and I want to become a good person"

Из этой строки, если я выберу «стать хорошим человеком» из текстовой области, то
Как я могу получить выбранную позицию текста / строки в JavaScript?


Здесь выбранный символ строки начинается с 29 и заканчивается 49. Таким образом, начальная позиция равна 29, а конечная позиция равна 49


1
Под позицией вы подразумеваете, что является индексом символа «b» и «становиться» в строке?
Палас

Я чувствую, что вопрос просто просит HTMLInputElement.selectionStart и selectionEnd, в то время как ответы в основном говорят о событии выбора. Нет смысла писать ответ, включенный во все остальные ответы.
JollyJoker

Ответы:


24

Это будет работать для выделения текста с помощью мыши и клавиатуры для всех элементов textarea на странице. Обязательно либо измените селектор и будьте более конкретны там, и читайте комментарии, если вы не хотите / не нуждаетесь в выборе клавиатуры.

var mySelection = function (element) {
    let startPos = element.selectionStart;
    let endPos = element.selectionEnd;
    let selectedText = element.value.substring(startPos, endPos);

    if(selectedText.length <= 0) {
      return; // stop here if selection length is <= 0
    }
    
    // log the selection
    console.log("startPos: " + startPos, " | endPos: " + endPos );
    console.log("selectedText: " +  selectedText);

  };

var textAreaElements = document.querySelectorAll('textarea');
[...textAreaElements].forEach(function(element) {
    // register "mouseup" event for the mouse
    element.addEventListener('mouseup', function(){
        mySelection(element)
    });
    
    // register "keyup" event for the keyboard
    element.addEventListener('keyup', function( event ) {
        // assuming we need CTRL, SHIFT or CMD key to select text
        // only listen for those keyup events
        if(event.keyCode == 16 || event.keyCode == 17 || event.metaKey) {
            mySelection(element)
        }
    });
});
textarea {
   resize: none; 
   width: 50%;
   height: 50px; 
   margin: 1rem auto;
}
<textarea>I am a student and I want to become a good person</textarea>


2
Довольно аккуратно. +1
Сахарш

2
Это не срабатывает, если вы выбираете с помощью клавиатуры, а не мыши.
curiousdannii

1
@curiousdannii Я обновил ответ, теперь он также работает с выбором клавиатуры
карамба

5

Я бы использовал событие onselect, чтобы получить то же самое.

<textarea id="input-text" onselect="myFunction(event)">I am a student and I want to become a good person</textarea>


<script>
    function myFunction(event) {
      const start  = event.currentTarget.selectionStart;
      const end= event.currentTarget.selectionEnd;
    }
</script>

1
    var idoftextarea='answer';
    function getSelectedText(idoftextarea){
        var textArea = document.getElementById(idoftextarea);
        var text =textArea.value;
        var indexStart=textArea.selectionStart;
        var indexEnd=textArea.selectionEnd;
        alert(text.substring(indexStart, indexEnd));

    }


    getSelectedText(idoftextarea);



1

Ответ Caramba работал довольно хорошо, однако у меня была проблема, что, если вы выбрали какой-то текст и выпустили мышь за пределы области текста , событие не сработало.

Чтобы решить эту проблему, я изменил исходное событие на mousedown, это событие регистрирует mouseupсобытие в документе, чтобы оно срабатывало после отпускания курсора. mouseupСобытие затем удаляет себя после того, как он выстрелил.

Это может быть достигнуто с помощью добавления onceопции addEventListener, но, к сожалению, не поддерживается в IE11, поэтому я использовал решение во фрагменте.

var mySelection = function (element) {
    let startPos = element.selectionStart;
    let endPos = element.selectionEnd;
    let selectedText = element.value.substring(startPos, endPos);

    if(selectedText.length <= 0) {
      return; // stop here if selection length is <= 0
    }
    
    // log the selection
    console.log("startPos: " + startPos, " | endPos: " + endPos );
    console.log("selectedText: " +  selectedText);
};

function addSelfDestructiveEventListener (element, eventType, callback) {
    let handler = () => {
        callback();
        element.removeEventListener(eventType, handler);
    };
    element.addEventListener(eventType, handler);
};

var textAreaElements = document.querySelectorAll('textarea');
[...textAreaElements].forEach(function(element) {
    // register "mouseup" event for those
    element.addEventListener('mousedown', function(){
      // This will only run the event once and then remove itself
      addSelfDestructiveEventListener(document, 'mouseup', function() {
        mySelection(element)
      })
    });
    
    // register "keyup" event for the keyboard
    element.addEventListener('keyup', function( event ) {
        // assuming we need CTRL, SHIFT or CMD key to select text
        // only listen for those keyup events
        if(event.keyCode == 16 || event.keyCode == 17 || event.metaKey) {
            mySelection(element)
        }
    });
});
textarea {
   resize: none; 
   width: 50%;
   height: 50px; 
   margin: 1rem auto;
}
<textarea>I am a student and I want to become a good person</textarea>


Мне нравится, как вы реализовали addSelfDestructiveEventListener!
Карамба

0
var mySelection = function (element) {
let startPos = element.selectionStart;
let endPos = element.selectionEnd;
let selectedText = element.value.substring(startPos, endPos);

if(selectedText.length <= 0) {
  return; // stop here if selection length is <= 0
}

// log the selection
console.log("startPos: " + startPos, " | endPos: " + endPos );
console.log("selectedText: " +  selectedText); };var textAreaElements = document.querySelectorAll('textarea'); 
[...textAreaElements].forEach(function(element) {
// register "mouseup" event for the mouse
element.addEventListener('mouseup', function(){
    mySelection(element)
});
// register "keyup" event for the keyboard
element.addEventListener('keyup', function( event ) {
    // assuming we need CTRL, SHIFT or CMD key to select text
    // only listen for those keyup events
    if(event.keyCode == 16 || event.keyCode == 17 || event.metaKey) {
        mySelection(element)
    }
});});

Можете ли вы добавить небольшое объяснение того, что делает ваш код?
Рэйчел Макгиган
Используя наш сайт, вы подтверждаете, что прочитали и поняли нашу Политику в отношении файлов cookie и Политику конфиденциальности.
Licensed under cc by-sa 3.0 with attribution required.