时间:2021-05-26
本文实例讲述了JavaScript让Textarea支持tab按键的方法。分享给大家供大家参考。具体实现方法如下:
HTMLTextAreaElement.prototype.getCaretPosition = function () {//return the caret position of the textarea return this.selectionStart;};HTMLTextAreaElement.prototype.setCaretPosition = function (position) {//change the caret position of the textarea this.selectionStart = position; this.selectionEnd = position; this.focus();};HTMLTextAreaElement.prototype.hasSelection = function () {//if the textarea has selection then return true if (this.selectionStart == this.selectionEnd) { return false; } else { return true; }};HTMLTextAreaElement.prototype.getSelectedText = function () {//return the selection text return this.value.substring(this.selectionStart, this.selectionEnd);};HTMLTextAreaElement.prototype.setSelection = function (start, end) {//change the selection area of the textarea this.selectionStart = start; this.selectionEnd = end; this.focus();};var textarea = document.getElementsByTagName('textarea')[0]; textarea.onkeydown = function(event) { //support tab on textarea if (event.keyCode == 9) { //tab was pressed var newCaretPosition; newCaretPosition = textarea.getCaretPosition() + " ".length; textarea.value = textarea.value.substring(0, textarea.getCaretPosition()) + " " + textarea.value.substring(textarea.getCaretPosition(), textarea.value.length); textarea.setCaretPosition(newCaretPosition); return false; } if(event.keyCode == 8){ //backspace if (textarea.value.substring(textarea.getCaretPosition() - 4, textarea.getCaretPosition()) == " ") { //it's a tab space var newCaretPosition; newCaretPosition = textarea.getCaretPosition() - 3; textarea.value = textarea.value.substring(0, textarea.getCaretPosition() - 3) + textarea.value.substring(textarea.getCaretPosition(), textarea.value.length); textarea.setCaretPosition(newCaretPosition); } } if(event.keyCode == 37){ //left arrow var newCaretPosition; if (textarea.value.substring(textarea.getCaretPosition() - 4, textarea.getCaretPosition()) == " ") { //it's a tab space newCaretPosition = textarea.getCaretPosition() - 3; textarea.setCaretPosition(newCaretPosition); } } if(event.keyCode == 39){ //right arrow var newCaretPosition; if (textarea.value.substring(textarea.getCaretPosition() + 4, textarea.getCaretPosition()) == " ") { //it's a tab space newCaretPosition = textarea.getCaretPosition() + 3; textarea.setCaretPosition(newCaretPosition); } } }希望本文所述对大家的javascript程序设计有所帮助。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
本文实例讲述了javascript实现textarea中tab键的缩排处理方法。分享给大家供大家参考。具体如下:网上搜索了一下相关的解决方法,其它的有使用两三行
我们在使用电脑的时候,键盘是必不可少的,在键盘上的Tab按键,是我们使用的基本按键,很多人还不了解其详细使用方法,首先我们来看看tab键的含义和使用方法和作用。
本文实例分析了JavaScript中Textarea滚动条不能拖动的解决方法。分享给大家供大家参考,具体如下:在IE中,你是否碰到过Textarea的滚动条不能
//JQuery为textarea添加maxlength//textarea默认不支持maxlength属性。//通过JQuery的keyup事件:JQuery
本文实例讲述了JavaScript实现为input与textarea自定义hover,focus效果的方法。分享给大家供大家参考。具体如下:这里演示JavaSc