解决oninput事件在中文输入法下会取得拼音的值的问题
在做搜索等功能时,很多时候我们需要实时获取用户输入的值,而常常会得到类似 w'm 这样的拼音。为了解决这个问题,我在网上搜索了下相关问题,发现了两个陌生的事件:compositionstart 和 compositionend。
compositionstart & compositionend
在 MDN 上找到了关于他们的描述,compositionstart 和 compositionend。简单点描述如下:
- compositionstart:在输入中文或者语音等需要等待一连串的输入的操作之前,compositionstart事件会触发。
- compositionend:在输入中文或者语音等完毕或取消时,compositionend事件会触发。
input 和 compositionend 的触发顺序导致的问题
注:以下为 chrome 浏览器下的测试结果,关于其他浏览器请看兼容说明!
和大多数人的想法一样,我考虑使用一个布尔值来判断是否在等待输入法的输入,然后在 input 事件中根据其布尔值决定是否获取输入的值,初始代码如下:
var isInputZh = false;
elem.addEventListener('compositionstart', function (e) {
  isInputZh = true;
}, false);
elem.addEventListener('compositionend', function (e) {
  isInputZh = false;
}, false);
elem.addEventListener('input', function (e) {
  if (isInputZh) return;
  var value = this.value;
  console.log(value);
  doSomething(value);
}, false);嗯。。看起来好像没啥问题,运行后,却有些让人摸不着头脑。在一段中文输入完毕后却并没有在控制台输出任何数据。嗯。。测试后发现 compositionend 事件是在 input 事件之后触发的。
解决方法
最后只能用常规方法去解决:在 compositionend 和 input 事件中都得加入对输入值的处理。代码如下:
var isInputZh = false;
var search = document.querySelector('input');
search.addEventListener('compositionstart', function (e) {
  isInputZh = true;
}, false);
search.addEventListener('compositionend', function (e) {
  isInputZh = false;
  doSomething(search.value);
}, false);
search.addEventListener('input', function (e) {
  if (isInputZh) return;
  var value = this.value;
  doSomething(value);
}, false);关于兼容说明
以上测试是在 chrome 浏览器下进行的,在 Firefox 和 Edge 浏览器下发现 input 事件在 compositionend 事件之后触发,且在输入数字时发现 Firefox 和 Edge 也会触发 compositionend 事件,以上内容仅在 chrome 浏览器中适用。
写在最后
原文发在 github。如果大家有什么好的解决方案欢迎在评论中提出。
解决oninput事件在中文输入法下会取得拼音的值的问题的更多相关文章
- 解决oninput在输入中文时,会获取拼音的问题
		(1)起因:在今天做项目测试的时候发现的问题,在用微软自带的输入法的时候,输入中文,文本框会获得拼音 如图所示: (2)解决办法:经过一段时间的百度查找,最后通过这篇文章找到了解决的方法,这里给出网址 ... 
- 移动APP 中文输入法下的搜索优化
		最近做了一个移动端的搜索功能,带有suggest.实现上并没有什么可说的,但是在后续优化上,特别是在中文输入法的情况下的优化使我学到一些新东西,所以决定写一篇文章. 下面是我简化后的基本功能实现,监听 ... 
- input事件以及中文输入法的处理
		在项目的开发过程中,相信大家都处理过监听用户输入的事情,一般我们会用到onkeyup.onkeydown.onkeypress.onchange.oninput事件,虽然都很熟悉了,但是还是有必要巩固 ... 
- wp中TextBox在中文输入法下清空问题
		如图,在中文输入法下我希望点击“X”,然后把TextBox清空,一般来说,直接用TextBox.Text = "";或者TextBox.Text = String.Empty;就可 ... 
- 树莓派3B/3B+ 清华镜像系统和安装中文输入法Fcitx及Google拼音输入法
		你还在为树莓派无法安装中文输入法而到处找教程吗? 你还在为树莓派每次下载都要远隔重洋获取资源,龟速下载而烦恼吗? 为了解决这个问题,在这篇树莓派教程中,我将手把手叫你怎样安装 清华镜像系统和中文输入法 ... 
- compositionEnd  和 input 事件(中文输入法问题)
		网上用 compositionstart + compositionend + input 解决中文输入法问题的办法 node.addEventListener('compositionstart', ... 
- 配置 .vimrc 解决 Vim / gVim 在中文 Windows 下的字符编码问题
		转载自:-杨博的日志 - 网易博客 Vim / gVim 在中文 Windows 下的字符编码有两个问题: 默认没有编码检测功能 如果一个文件本身采用的字符集比 GBK 大(如 UTF-8.UTF-1 ... 
- input中用中文输入法下的全角·替换英文输入法下的句号.
		核心语句 <input type="text" onkeyup="this.value=this.value.replace(/\./g, '·')" o ... 
- html5手机网页开发,中文输入法下软键盘遮挡输入框
		安卓手机解决办法 微信UI框架weui中给出了解决方法:weui框架http://weui.github.io/weui/example.js // .container 设置了 overflow 属 ... 
随机推荐
- Codeforces Round #579 (Div. 3)  Complete the Projects(贪心、DP)
			http://codeforces.com/contest/1203/problem/F1 Examples input 1 - - output 1 YES input 2 - - output 2 ... 
- [LC] 270. Closest Binary Search Tree Value
			Given a non-empty binary search tree and a target value, find the value in the BST that is closest t ... 
- RPM包和YUM仓库管理
			1.RPM包管理 RPMRPM Package Manger,前身Redhat Package Manger,由红帽开发用于软件包的安装升级卸载与查询有一个完整的数据库体系,每个RPM包的所有信息都固 ... 
- 安装Rational Rose启动报错:无法启动此程序,因为计算机中丢失 suite objects.dll。
			运行Rational Rose的时候如果出现这样的错误,先检查环境变量有没有common的地址,如果没有直接配上就OK:配置如下:D:\Program Files\Rational\Common; 我 ... 
- DataGrip设置时区
			新版本DataGrip以默认时区取世界标准时间.要想时间显示正常,需要将时区变为上海时区,可手动在连接配置里设置参数.如下图: 操作步骤1.右键打开你想要修改的数据库连接的Properties菜单:2 ... 
- laravel中用到的ServiceProvide
			路由 全局限制 如果你希望路由参数可以总是遵循正则表达式,则可以使用 pattern 方法.你应该在 RouteServiceProvider 的 boot 方法里定义这些模式: 1 2 3 4 5 ... 
- F5 BIG-IP LTM会话保持
- Linux安装swoole拓展 (一键安装lnmp后安装可用完美)
			一键安装lnmp后安装可用完美 swoole(一键安装完lnmp重启下,之前出现502一直解决不了,不清楚啥情况) 找到对应php版本,在lnmp文件夹的src 1.安装swoole cd /usr/ ... 
- django自带数据库sqlite
			python manage.py makemigrations # 记录关于models.py的所有改动,但是还没有作用的数据库文件中 python manage.py migrate # 把mode ... 
- windows下apache运行环境搭建
			apache的安装 要求: 1,不要安装到有中文的目录中: 2,尽量将apache,php,mysql安装到一个总的目录,便于管理.(如都建立在amp目录下,然后在该目录下分别建立apache,php ... 
