input输入中文时,拼音在输入框内会触发input事件的问题。

时间:2022-04-28 04:48:50

问题描述:

  监听文本输入框的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,接下来贴出示例代码

<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<script src="http://libs.baidu.com/jquery/1.8.3/jquery.min.js"></script>
<title></title>
</head>
<body>
<input id="txt" type="text">
<script>
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)
})
</script>
</body>
</html>

 

 

效果图:

input输入中文时,拼音在输入框内会触发input事件的问题。

 

 

tips:
  为什么使用延时器?
  因为选词结束的时候input会比compositionend先一步触发,此时flag还未调整为true,所以不能触发到console,故用setTimeout将其优先级滞后。