我想要一个通过触发特定击键来动态验证的输入元素(type=text)或 textarea 元素。这将用于中文拼音输入,例如:
用户在输入元素中键入“ma2”。每次击键都会触发 keydown 事件,并且 2 永远不会出现。相反,当用户按下“2”时,“a”将收到一个音标,例如:“á”。最后,用户将输入:“má”。
这可以通过使用 $(element).val() 读取和更改整个输入值来完成,但是,当输入元素具有焦点并且通过调用 .val("something") 设置其值时,光标将移动到末尾的文本。这在大多数情况下都可以正常工作,因为用户只是在字段末尾继续输入,但我希望这在所有情况下都能正常工作。
...这个问题的另一个解决方案是获取/设置光标在输入或文本区域元素中的位置。但是,我认为这在 javascript 中是不可能的。
所以,雷米肯定是在正确的轨道上。无论如何,触发按键不会让我输入特殊字符而没有很多麻烦。相反,我捕获 keydown 事件并设置输入/文本区域的值,然后移动插入符号。
我还没有发现任何有利于在 jQuery 中获取/设置插入符号的东西,但是下面的内容确实为我解决了这个问题。当它稳定时,我会发布一个指向我的最终拼音输入代码的链接。现在已经很接近了。
http://blog.vishalon.net/Post/57.aspx http://demo.vishalon.net/getset.htm