The old version of the question is below, after researching more, I decided to rephrase the question. The problem as before is, I need to focus a contenteditable div without highlighting the text, doing straight up focus highlights the text in Chrome.
I realize that people solved this problems in textareas by resetting the caret position in the textarea. How can I do that with a contenteditable element? All the plugins I've tried only works with textareas. Thanks.
Old Phrasing of the question:
I have a contenteditable element that I want to focus, but only insofar as to place the cursor at the front of the element, rather selecting everything.
elem.trigger('focus');
with jquery selects all the text in the entire element in chrome. Firefox behaves correctly, setting the caret at the front of the text. How can I get Chrome to behave the way I want, or is focus perhaps not what I'm looking for.
Thanks all.
Set pointer position in pre or div tag:
Source: https://social.msdn.microsoft.com/Forums/en-US/f91341cb-48b3-424b-9504-f2f569f4860f/getset-caretcursor-position-in-a-contenteditable-div?forum=winappswithhtml5
Yes it happens because you have used
try to use class or to identify the element on which you want to fire a trigger event.
Maybe I'm misreading the question, but wouldn't the following do (assuming an editable
<div>
with id "editable")? The timer is there because in Chrome, the native browser behaviour that selects the whole element seems to trigger after thefocus
event, thereby overriding the effect of the selection code unless postponed until after the focus event:I managed to solve that problem after a bit of poking around the DOM.
It probably only works on WebKit browsers, but since it is the only source of the problem, I added a conditional (using jQuery)
Hope this solves your problem.