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

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

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

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

    阻止中文输入时触发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.2K20

    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.8K20

    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.8K10

    Jenkins触发构建--事件触发

    事件触发 事件触发就是发生了某个事件触发pipeline执行,这个事件可以是你能想到的任何事件,比如手动在界面上触发、其它job主动触发、HTTP API Webhook触发等。...gitlab通知触发是指当gitlab发现源代码有变化时,触发jenkins执行构建。...Jenkins发现你的test-a项目开启了这个触发功能,就会根据pipeline的配置进行相应处理,符合条件后就会触发执行。...,看是否jenkins job被触发了 8.然后在gitlab项目中,随意修改个文件,看是否也能自动触发 9.参数含义 riggerOnPush: 当Gitlab触发push事件时,是否执行构建 triggerOnMergeRequest...: 当Gitlab触发mergeRequest事件时,是否执行构建 branchFilterType: 只有符合条件的分支才会触发构建,必选,否则无法实现触发

    5.8K20

    input 事件监听

    1、change事件,在input失去焦点才会考虑触发,它的缺点是无法实时响应,与blur事件有着相似的功能,但与blur事件不同的是,change事件在输入框的值未改变时并不会触发,当输入框的值和上一次的值不同...,并且输入框失去焦点,就会触发change事件。...2、input事件,需要实时检测input输入框的值的时候,就需要用到h5的新事件:input事件了,input事件可以实现对input输入框值的实时监控,只要input输入框值发生改变就会触发,但因为是...h5的新事件,应此需要考虑兼容性问题,ie9以下的浏览器并没有实现这个事件, 3、propertychange事件,这个事件是在input的属性值发生改变时触发,而输入框的值就是input的value属性...propertychange事件实时触发,即每增加一个字符或者删除一个字符就会触发,通过js也会触发(任何属性改变),但是该事件为ie专有input是ie之外大多数浏览器支持的事件,在value改变时触发

    4.6K20

    代码触发,手动触发touchstart事件,touch事件,click事件,自定义事件

    工作中有时候会用到需要用代码去手动触发某个事件或者是自定义事件,通常触发click事件的做法为eleme.click(),遇到touchstart就行不通了。...可以使用以下方式 // 创建事件. var event = document.createEvent('Events'); // 初始化一个点击事件,可以冒泡,无法被取消 event.initEvent...e.target 就是监听事件目标元素 }, false); // 触发事件监听 elem.dispatchEvent(event); initEvent已经从 Web 标准中删除,虽然一些浏览器目前仍然支持它...new Event('touchstart'); //监听 elem.addEventListener('touchstart', function (e) { ... }, false); // 触发...('CustomEvent', function (e) { ... }, false); // 触发event elem.dispatchEvent(event); 发布者:全栈程序员栈长,转载请注明出处

    4.8K30

    【js】Input事件

    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.3K30

    input元素的oninput事件和onchange事件

    input元素的oninput事件和onchange事件 框架用多了,感觉原生的有点弱化了,不说了,是时候巩固一波了 ^ _ ^ 1、input元素上绑定事件的三种方式: 第一种:直接在元素标签上添加oninput...handleInput() } function handleInput() { // 处理事件代码 } 第三种:获取input元素,然后在元素上利用事件监听添加input事件 <input...('input', handleInput) function handleInput() { // 处理事件代码 } 2、input元素的oninput事件和onchange事件的区别 oninput...事件是在输入框中输入时就会触发 onchange事件是在输入框输入完内容后,输入框失焦后触发 onchange事件兼容性好,主流浏览器都支持 oninput事件IE9以下不支持,其余主流浏览器都支持,针对...IE9以下的可以使用onpropertychange事件来替代 参考文献: [1] oninput 事件 [2] input输入框的input事件和change事件 发布者:全栈程序员栈长,转载请注明出处

    3.4K10
    领券