I've written a bit of code in my keyboard event handler to insert a <br>
in response to the press of the Enter key:
event.preventDefault();
document.execCommand('InsertHTML', true, '<br>');
This only works if the cursor is between two Letters, if its on the end i need two <br>
-Elements. Can i detect if i'm on the end of a Line? Or some other working idea for the Enter problem?
I also tried to catch the normal key-event (wothout the ctrl-Key pressed) and create a keyboard-event with JS where the Enter Key is pressed together with the ctrl. But this dosn't work…
It only has to Work in Webkit/Safari…
I would bind a function to the keyup event to delete and change to
using regEx. So even if it creates strange markup, it will be fixed.
Using jQuery:
In order to solve your problem, always keep a br element as the last element of your contenteditable div. This will ensure predictable behavior when injecting a br element vs. the browser default of injecting div elements. You can check the lastChild on keyup and mouseup to make sure it's a br element. Assuming you have a document like:
You can use the following JavaScript (w/ jQuery 1.4+) to keep a br element as the last element and inject a br element instead of div div:
Tested on Apple OS X w/ Google Chrome 7, Mozilla Firefox 3.6, Apple Safari 5). Try using ierange to get this to work in Windows Internet Explorer.