解决input输入中文时,拼音在输入框内会触发input事件的问题 |
您所在的位置:网站首页 › 页面的拼音怎么拼写 › 解决input输入中文时,拼音在输入框内会触发input事件的问题 |
问题描述:
监听文本输入框的input事件,在拼写汉字(输入法)但汉字并未实际填充到文本框中(选词)时会触发input事件,如图: 需求:选词完成后触发input事件,只触发一次。 解决办法:通过查阅资料得知在输入中文(包括语音识别时)会先后触发compositionstart、compositionend事件,类似于keydown和keyup的组合。 触发compositionstart时,文本框会填入 “虚拟文本”(待确认文本),同时触发input事件;在触发compositionend时,就是填入实际内容后(已确认文本)。 先看看 compositionstart 的描述 和 compositionend 的 描述 compositionstart 事件触发于一段文字的输入之前(类似于 keydown 事件,但是该事件仅在若干可见字符的输入之前,而这些可见字符的输入可能需要一连串的键盘操作、语音识别或者点击输入法的备选词)。 compositionend 当文本段落的组织已经完成或取消时,会触发该事件。 个人理解:compositionstart 在输入一段需要确认的文本如拼音to汉字、语音时会触发 compositionend 在拼音选词完成、语音输入完毕时会触发 至此,思路get: 声明一个标记flag,在compositionstart、compositionend两个事件过程之间的时候flag值为false,在input事件中通过flag的值来判断当前输入的状态。 OK,接下来贴出示例代码 var flag = true; $('#txt').on('compositionstart',function(){ flag = false; }) $('#txt').on('compositionend',function(){ flag = true; }) $('#txt').on('input',function(){ var _this = this; setTimeout(function(){ if(flag){ console.log($(_this).val()); } },0) })效果图: tips: 为什么使用延时器? 因为选词结束的时候input会比compositionend先一步触发,此时flag还未调整为true,所以不能触发到console,故用setTimeout将其优先级滞后。 |
今日新闻 |
推荐新闻 |
CopyRight 2018-2019 办公设备维修网 版权所有 豫ICP备15022753号-3 |