Jak uzyskać wybraną pozycję tekstową z obszaru tekstowego w JavaScript?

20

Chcę uzyskać wybraną pozycję tekstową za pomocą javascript. Na przykład
mam prosty obszar tekstowy.

#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>

W moim obszarze tekstowym mam trochę tekstu, takiego jak:

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

Z tego ciągu, jeśli wybiorę „zostań dobrą osobą” z obszaru
tekstowego , to jak mogę uzyskać zaznaczoną pozycję tekstu / ciągu w javascript?


Tutaj wybrany znak ciągu zaczyna się od 29 i kończy na 49. Zatem pozycja początkowa to 29, a pozycja końcowa to 49

MD Tahazzot
źródło
1
Przez pozycję rozumiesz, jaki jest indeks znaku „b” dla „stać” w ciągu?
palašн
Wydaje mi się, że pytanie dotyczy tylko HTMLInputElement.selectionStart i selectionEnd, podczas gdy odpowiedzi głównie mówią o zdarzeniu selekcji. Nie ma jednak sensu pisać odpowiedzi zawartej we wszystkich pozostałych odpowiedziach.
JollyJoker
1
Czy to odpowiada na twoje pytanie? Jak uzyskać zaznaczony tekst z kontrolki
pola

Odpowiedzi:

24

Działa to przy zaznaczaniu tekstu za pomocą myszy i klawiatury dla wszystkich elementów obszaru tekstowego na stronie. Pamiętaj, aby zmienić selektor i być bardziej szczegółowym oraz przeczytać komentarze, jeśli nie chcesz / potrzebujesz wyboru klawiatury.

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>

karamba
źródło
2
Całkiem nieźle. +1
Saharsh
2
Nie uruchamia się, jeśli wybierzesz używanie klawiatury zamiast myszy.
curiousdannii
1
@curiousdannii Zaktualizowałem odpowiedź, teraz działa również z wyborem klawiatury
caramba
5

Korzystam z zdarzenia onselect , aby uzyskać to samo.

<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>
Dreamweaver
źródło
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);

Nourhan Ahmed
źródło
1

Odpowiedź Caramba działała całkiem nieźle, ale miałem problem z tym, że jeśli wybierzesz jakiś tekst i zwolnisz mysz poza obszarem tekstowym , wydarzenie nie zostanie uruchomione.

Aby rozwiązać ten problem, zmieniłem początkowe zdarzenie na mousedown, to zdarzenie rejestruje mouseupzdarzenie w dokumencie, aby zapewnić jego uruchomienie po zwolnieniu kursora. mouseupWydarzenie następnie usuwa się po jego zwolniony.

Można to osiągnąć, dodając onceopcję do addEventListener, ale niestety nie jest obsługiwana w IE11, dlatego użyłem rozwiązania we fragmencie.

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>

Hiws
źródło
Podoba mi się jak wdrożyłeś addSelfDestructiveEventListener!
caramba
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)
    }
});});
Jaser Abdel-Maksoud
źródło
Czy możesz dodać małe wyjaśnienie do tego, co robi kod?
Rachel McGuigan