jQuery Установить положение курсора в текстовой области

В отсутствие общего решения, я думаю, есть две вещи, которые следует учитывать:

  1. Избегайте многоколоночных первичных ключей (также упростит модульное тестирование).
  2. Но если вам нужно, возможно, что один из них уменьшит размер результата запроса до O (n), где n - размер идеального результата запроса. Отсюда, его решение 5 от Герда Арнольда выше.

Например, проблема, ведущая меня к этому вопросу, заключалась в том, чтобы запросить строки порядка, где ключ - идентификатор заказа + номер строки заказа + тип заказа , и источник имел тип неявного типа. То есть тип заказа был константой, идентификатор заказа уменьшал бы запрос, заданный для порядка строк соответствующих заказов, и обычно их было бы 5 или меньше.

Чтобы перефразировать: если у вас есть составной ключ, изменения в том, что один из них имеет очень мало дубликатов. Примените решение 5 сверху.

431
задан Soul_man 21 March 2014 в 00:05
поделиться

5 ответов

У меня есть две функции:

function setSelectionRange(input, selectionStart, selectionEnd) {
  if (input.setSelectionRange) {
    input.focus();
    input.setSelectionRange(selectionStart, selectionEnd);
  }
  else if (input.createTextRange) {
    var range = input.createTextRange();
    range.collapse(true);
    range.moveEnd('character', selectionEnd);
    range.moveStart('character', selectionStart);
    range.select();
  }
}

function setCaretToPos (input, pos) {
  setSelectionRange(input, pos, pos);
}

Затем можно использовать setCaretToPos как это:

setCaretToPos(document.getElementById("YOURINPUT"), 4);

Живой пример и с textarea и с input, показывая использование из jQuery:

function setSelectionRange(input, selectionStart, selectionEnd) {
  if (input.setSelectionRange) {
    input.focus();
    input.setSelectionRange(selectionStart, selectionEnd);
  } else if (input.createTextRange) {
    var range = input.createTextRange();
    range.collapse(true);
    range.moveEnd('character', selectionEnd);
    range.moveStart('character', selectionStart);
    range.select();
  }
}

function setCaretToPos(input, pos) {
  setSelectionRange(input, pos, pos);
}

$("#set-textarea").click(function() {
  setCaretToPos($("#the-textarea")[0], 10)
});
$("#set-input").click(function() {
  setCaretToPos($("#the-input")[0], 10);
});
<textarea id="the-textarea" cols="40" rows="4">Lorem ipsum dolor sit amet, consectetur adipiscing elit, sed do eiusmod tempor incididunt ut labore et dolore magna aliqua. Ut enim ad minim veniam, quis nostrud exercitation ullamco laboris nisi ut aliquip ex ea commodo consequat. Duis aute irure dolor in reprehenderit in voluptate velit esse cillum dolore eu fugiat nulla pariatur. Excepteur sint occaecat cupidatat non proident, sunt in culpa qui officia deserunt mollit anim id est laborum.</textarea>
<br><input type="button" id="set-textarea" value="Set in textarea">
<br><input id="the-input" type="text" size="40" value="Lorem ipsum dolor sit amet, consectetur adipiscing elit">
<br><input type="button" id="set-input" value="Set in input">
<script src="https://ajax.googleapis.com/ajax/libs/jquery/1.11.1/jquery.min.js"></script>

По состоянию на 2016, протестированный и работающий над Chrome, Firefox, IE11, даже IE8 (см. что в последний раз здесь ; Отрывки Стека не поддерживают IE8).

252
ответ дан T.J. Crowder 21 March 2014 в 00:05
поделиться
  • 1
    Отредактированный теперь. Неправильно отправленный! Хорошая выгода. Вы правы. – Easwaramoorthy K 16 July 2012 в 03:14

Вот решение jQuery:

$.fn.selectRange = function(start, end) {
    if(end === undefined) {
        end = start;
    }
    return this.each(function() {
        if('selectionStart' in this) {
            this.selectionStart = start;
            this.selectionEnd = end;
        } else if(this.setSelectionRange) {
            this.setSelectionRange(start, end);
        } else if(this.createTextRange) {
            var range = this.createTextRange();
            range.collapse(true);
            range.moveEnd('character', end);
            range.moveStart('character', start);
            range.select();
        }
    });
};

С его помощью вы можете do

$('#elem').selectRange(3,5); // select a range of text
$('#elem').selectRange(3); // set cursor position
297
ответ дан 22 November 2019 в 23:15
поделиться

В IE для перемещения курсора в какую-либо позицию достаточно этого кода:

var range = elt.createTextRange();
range.move('character', pos);
range.select();
6
ответ дан 22 November 2019 в 23:15
поделиться

Я использую это: http://plugins.jquery.com/project/jcaret

7
ответ дан 22 November 2019 в 23:15
поделиться

Это сработало для меня в Safari 5 на Mac OSX, jQuery 1.4:

$("Selector")[elementIx].selectionStart = desiredStartPos; 
$("Selector")[elementIx].selectionEnd = desiredEndPos;
10
ответ дан 22 November 2019 в 23:15
поделиться
Другие вопросы по тегам:

Похожие вопросы: