可以将文章内容翻译成中文,广告屏蔽插件可能会导致该功能失效(如失效,请关闭广告屏蔽插件后再试):
问题:
I'm using a regular expression to strip invalid characters out of an text input area in javascript (running in IE). I run the replace function on every keyup event. However, this makes the cursor jump to the end of the text box after each keypress, which makes inline editing impossible.
Here is it in action:
http://jsbin.com/ifufuv/2
Does anyone know how to make it so the cursor does not jump to the end of the input box?
回答1:
You'll have to manually put the cursor back where you want it. For IE9, set .selectionStart
and .selectionEnd
(or use .setSelectionRange(start, end)
). For IE8 and earlier, use .createTextRange()
and call .moveStart()
on the text range.
回答2:
In addition to gilly3's answer, I thought someone might find it useful to see an actual code snippet.
In the example below, the selectionStart
property is retrieved from the input
element prior to the JavaScript string manipulation. Then selectionStart
is set back to the initial position after the manipulation.
Depending on what you're trying to achieve, you could also access selectionEnd
in place of selectionStart
, and set a range: setSelectionRange(start, end)
.