首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

input输入中文时,拼音触发input事件

在上一篇文章中写到了函数防抖,在使用函数防抖来进行搜索框优化的时候会遇到一个问题,就是监听文本输入框的input事件,在拼写汉字(输入法)但汉字并未实际填充到文本框中时会触发input事件,会出现下图的效果...这是我们不希望看到的,我们希望得到的效果是汉字输入进去以后再触发事件。 通过查询,我发现input有两个事件:compositionstart和compositionend。...来看一下关于两个事件的介绍: compositionstart:事件触发于一段文字的输入之前(类似于 keydown 事件,但是该事件仅在若干可见字符的输入之前,而这些可见字符的输入可能需要一连串的键盘操作...、语音识别或者点击输入法的备选词)。...个人可以理解为输入拼音状态开始执行的事件 compositionend:当文本段落的组织已经完成或取消时,会触发事件。这个个人可以理解为输入拼音结束,按下空格将汉字输入完成以后执行的事件

7.8K20
您找到你想要的搜索结果了吗?
是的
没有找到

jsInput事件

Input Event常用事件触发的先后顺序如下: 1 keydown 2 keypress 3 textInput 4 input 5 keyup keydown,keyup 1 全部浏览器支持 2...4 event.charCode = 0 这两个事件触发时,总返回0 keypress 1 全部浏览器支持 2 当用户按下字符键时触发 3 event.charCode,返回键盘上按键对应的ASCII码...,便于检查拦截用户输入使用 3 在input:text,input:password,input:search,textarea以及元素是contentEditable模式时支持触发事件 4 event.data...,Chrome,Safari,Opera支持 2 在内容变化时,实时触发 3 在input:text,input:password,input:search,textarea支持触发事件,在内容变化时...,实时触发 (与onchange事件类似,但是onchange事件只有在元素失去焦点的时候才触发) 4 IE9中此事件有bug,在多种删除方式(使用退格键(Backspace),删除键(Delete),

10.2K30

阻止中文输入时触发input事件

做限制输入框可输入最大的长度和实时匹配输入框数据时遇到了坑 —— 当中文输入时input事件也会被触发,即假设限制的是2个字符,你要输入社会人的“社(she)”,就会直接被截取,输入框填充文本sh。...代码如下: $(document).on('input','input',function(){ console.log('限制最大输入字符(截取)') }) 这个问题,可以声明一个inputFlag...使用compositionstart,compositionend配合解决,代码如下: var inputFlag = true $(document).on('compositionstart', 'input...',function () { inputFlag = true }).on('compositionend','input',function () { inputFlag...= false }).on('input','input', function () { //定时器内才会生效 注意:定时器内this指向已发生改变 setTimeout(function

1.1K20

input获取焦点 原生js_原生jsinput事件

1.onfocus 当input 获取到焦点时触发 2.onblur 当input失去焦点时触发,注意:这个事件触发的前提是已经获取了焦点再失去焦点的时候才会触发事件,用于判断标签为空。...4.onkeydown 按下按键时的事件触发, 5.onkeyup 当按键抬起的时候触发事件,在该事件触发之前一定触发了onkeydown事件–相当于一个按键,两个事件,没怎么用过 6.onclick...主要是用于 input type=button,input作为一个按钮使用时的鼠标点击事件 7.onselect 当input里的内容文本被选中后执行,只要选择了就会触发,不是全部选中 8.oninput...当input的value值发生变化时就会触发,(与onchange的区别是不用等到失去焦点就可以触发了) 使用方法: 以上事件可以直接放到input的属性里,例如: 1 , 可以通过jsinput...dom元素添加相应的事件, 2 document.getElementByTagName(‘input’).onfocus = function(); 3 事件监听。

25.3K60

element 输入框点击事件_ElementUI的input事件问题

最近用ElementUI的el-input组件,然后发现一个问题, 就是我在输入框后,加一个icon的button, 然后我希望这个输入框可以触发两个事件, 第一个是,输入完,按键盘回车键的事件, 第二个是...然后翻阅文档,发现可以给input加@change事件,这样按回车可以搜索,然后可以把icon的button写成slot的方式然后给button加@click事件,这样按钮也能搜索。...但是问题来了,我给input加了@change事件,但是他这个change很坑,因为他change事件里不光包含回车,居然还有失焦。。。...这个时候我们想一下,用户按了回车,change事件触发,这没问题。 但是用户如果输入完,鼠标点右边的icon的button。。。完了。。。...这change(因为失焦)和click(因为点击了button)一起触发。。我特么。。。我人都傻了。。这什么鬼设定。。 有没有大佬有办法的,我感觉这个change带失焦好恶心。。

2.9K20

小程序如何避免多次点击,重复触发事件

1、点击事件是执行网络请求(提交评论,验证码,支付) 这种情况下可以在请求执行之前显示一个模式的加载框,请求完成后再关闭加载框。...util.hideLoading() ... }, fail: function (res) { util.hideLoading() ... } }) } 2、点击事件是页面跳转...当点击事件需要页面跳转时,不太适合显示加载框,但小程序的页面跳转并不是很快,如果不作处理又会导致用户反复点击打开多个页面,这里可以使用限制按钮或控件的点击间隔的方式处理,同样可以将这个方法放到公共的代码里面比如...setTimeout(function () { self.setData({ buttonClicked: false }) }, 500) } 首先需要在页面对应的js...文件里面增加一个buttonClicked数据对象,然后在点击事件里面调用上述方法。

5.9K50

input 事件

input 事件 1.onfocus 当input 获取到焦点时触发 2.onblur 当input失去焦点时触发,注意:这个事件触发的前提是已经获取了焦点再失去焦点的时候会触发相应的js 3.onchange...当input失去焦点并且它的value值发生变化时触发 4.onkeydown 在 input中有键按住的时候执行一些代码 5.onkeyup 在input中有键抬起的时候触发事件,在此事件触发之前一定触发了...onkeydown事件 6.onclick 主要是用于 input type=button,当被点击触发事件 7.onselect 当input里的内容文本被选中后执行一段,只要选择了就会触发,不是非得全部选中...// 8.oninput 当input的value值发生变化时就会触发,不用等到失去焦点(与onchange的区别) <input type="text" onfocus="a();" onblur

1.6K20

【Node.JS事件的绑定与触发

往期文章 【Node.JS】写入文件内容 【Node.JS】读取文件内容 目录 简介 绑定事件 on() addListener()  once() 监听事件emit()  传参  删除事件 removeListener...()  removeAllListeners() ---- 简介 node.js事件是使用events模块,通过实例化它里面的EventEmitter类,来绑定和监听事件。...event.emit('namea', '小解');  once() once 只会绑定一次性的触发事件触发一次后就会解除绑定。...进行实例化声明 on once addListener event.once('namea', function (a) { console.log(`坚毅的${a}同志`); }) //触发事件冰川入参数...('namea', function () { console.log("坚毅的小解同志"); }) //触发事件 event.emit('namea'); 通过emit来进行触发事件

11K40

IE中输入框绑定input事件触发解析(input事件初始化自动执行问题解决)

在React项目中碰到了个问题,输入框绑定了input事件,在IE中初始化会自动执行,刚开始以为是只要有placeholder就会导致问题,后面网上搜了一轮,自己手撸了一下,总结了导致绑定的input事件自动执行的原因...) 出现问题的代码如下 var input = document.createElement('input'); input.placeholder = '3333';...let listenCb = function(e){ alert('input执行了'); } input.addEventListener('input...,绑定完input事件之后,不能有placeholder的变化 我的解决思路是,获得焦点时再去监听input事件,如果input变化时可能涉及到placeholder的变化(react里面会这样),要同时去掉...placeholder;失去焦点时就取消监听input事件,同时恢复placeholder(如果获得焦点时有去掉),核心代码如下: //input是dom节点 let listenCb

1.7K10
领券