模拟文本输入字段上的退格键
simulate backspace key on text input field
有人能提供一个很好的例子来模拟<INPUT>
文本字段上的退格键吗?
我需要这个在HTML5中完成的虚拟键盘,它只需要在Webkit浏览器中工作。
注意:
- 具有charcode 8(退格)的
createEvent
/initTextEvent
/dispatchEvent
被忽略(这似乎只适用于可打印字符) - 使用
substr()
类型手动更改value
是有效的,但这样插入符号会移动到输入字段的末尾(我希望能够删除输入字段中间的字符,就像使用普通键盘一样)
好了,开始吧:http://jsfiddle.net/dan_barzilay/WWAh7/2/
如果需要更多解释性注释,get插入符号函数用于知道在哪里删除字符。重置光标功能用于在退格后恢复插入符号的位置。
**它使用的是jquery,但您可以在secounds 中将其更改为普通js
Edit:下面的内容太复杂了,无法使用。根据https://developer.mozilla.org/en-US/docs/Web/API/Document/execCommand,只要调用CCD_ 7就足够了。
以下是我使用setSelectionRange
的解决方案,它在Chrome上运行良好:https://github.com/gdh1995/vimium-plus/blob/master/lib/dom_utils.js#L169
simulateBackspace: function(element) {
var start = element.selectionStart, end = element.selectionEnd, event;
if (!element.setRangeText) { return; }
if (start >= end) {
if (start <= 0 || !element.setSelectionRange) { return; }
element.setSelectionRange(start - 1, start);
}
element.setRangeText("");
event = document.createEvent("HTMLEvents");
event.initEvent("input", true, false);
element.dispatchEvent(event);
}
好吧,唯一的不足是我们无法撤销它所做的改变。
添加:我找到了一个方法来启用undo&重做:在Javascript文本区域undo-redo中,这两个anwser在Chrome 上运行良好
相关文章:
- 让文本输入幻灯片显示输入时的新文本输入?然后向后滑动
- Sails.js:同时发布文本输入和一个文件
- 来自文本输入null的html javascript变量
- 当没有文本输入聚焦时检测空格键按下
- JS中的按钮和文本输入
- JavaScript:在调用函数的文本输入上按enter键
- jQuery自动完成功能不适用于多个文本输入
- 使用JS从选择和文本输入中捕获值,并将输出返回到HTML
- 如何通过jQuery发送选定的元素和文本输入
- HTML如何根据javascript函数的返回值限制文本输入
- jquery插件或javascript方法自动调整文本输入(而非文本区域)(固定宽度)可变高度的大小
- 在jquery中获取文本输入val始终为空
- HTML文本输入大小
- 文本输入与文本区域
- 角度ui选择标记模糊时丢失文本输入
- 文本输入值中的JavaScript变量
- Angular指令中的最佳实践是将文本输入设置为英尺和英寸的格式
- 如何在不通过模型验证的情况下屏蔽文本输入中输入的字符
- 在文本输入区域中创建双向更新
- 不使用自定义CSS或HTML(使用框架方法)的角度材质文本输入或文本区域标签大小