This was my solution with jQuery...
JavaScript
$(document).delegate('textarea', 'keydown', function(e) {
var keyCode = e.keyCode || e.which;
if (keyCode == 9) {
e.preventDefault();
var start = this.selectionStart;
var end = this.selectionEnd;
var text = $(this).val();
var selText = text.substring(start, end);
$(this).val(
text.substring(0, start) +
"\t" + selText.replace(/\n/g, "\n\t") +
text.substring(end)
);
this.selectionStart = this.selectionEnd = start + 1;
}
});
This code allows for tabs to be inserted between characters in the textarea like so...
data:image/s3,"s3://crabby-images/4840a/4840af743fbc3f5e702d8e1ddff65d8ac4e032df" alt="htmltexareatab_1.png htmltexareatab_1.png"
It also works for inserting a tab at the start of the line...
data:image/s3,"s3://crabby-images/094a8/094a8b0cc35c38bef8193dfc7c6dd0ba10f1c01a" alt="htmltexareatab_2.png htmltexareatab_2.png"
Most importantly however, it works when selecting multiple lines and pressing Tab. Each of the lines is indented with a Tab character...
data:image/s3,"s3://crabby-images/717db/717dba8c9eb8e5749f246b626220f616cd98687e" alt="htmltexareatab_3.png htmltexareatab_3.png"
data:image/s3,"s3://crabby-images/fb626/fb6269105512d40a1787273fff0ca2b0e22e8439" alt="htmltexareatab_4.png htmltexareatab_4.png"
The code above intercepts Tab key presses for any textarea component. It then works out whether anything is selected and then inserts the Tab character into all of the appropriate spots. Once all the Tabs are inserted, the text cursor is set back to the beginning of the originally selected text.
-i