js用延时器优化input实时检测,及中文输入优化

在开发中会经常碰到要求监测input输入框的值来进行ajax查询,每次按键都会触发查询,这样耗费性能,可以通过延时器来优化,频繁输入时不进行查询,只有超过延时时间才会进行查询

oninput 当输入框的值发生改变时触发该事件

经过测试 0.5s是一个合适的时间,既不影响输入,又能有效拦截频繁的输入


    


  1. propertychange:
    功能同oninput,用以替代oninput在IE9以下的不兼容性。
  2. oninput 和 onchange:
    oninput和onchange都是事件对象,当输入框的值发生改变时触发该事件。不同的是,oninput是在值改变时立即触发,而onchange是在值改变后失去焦点才触发,并且可以用在非输入框中,如:select等。
  3. onchange 事件与 onpropertychange 事件的区别:
    onchange 事件在内容改变(两次内容有可能还是相等的)且失去焦点时触发。
    onpropertychange 事件却是实时触发,即每增加或删除一个字符就会触发,通过 js 改变也会触发该事件,但是该事件 IE 专有。
  4. oninput 事件与 onpropertychange 事件的区别:
    oninput 事件是 IE 之外的大多数浏览器支持的事件,在 value 改变时触发,实时的,即每增加或删除一个字符就会触发,然而通过 js 改变 value 时,却不会触发。
    onpropertychange 事件是任何属性改变都会触发的,而 oninput 却只在 value 改变时触发,oninput 要通过 addEventListener() 来注册,onpropertychange 注册方式跟一般事件一样。(此处都是指在js中动态绑定事件,以实现内容与行为分离)
  5. oninput 与 onpropertychange 失效的情况:
    (1)oninput 事件:a). 当脚本中改变 value 时,不会触发;b).从浏览器的自动下拉提示中选取时,不会触发。
    (2)onpropertychange 事件:当 input 设置为 disable=tru e后,onpropertychange 不会触发。

在输入中文时每次按键都会触发事件,而想要的是只有中文再触发

使用两个较新的事件:兼容ie9+

compositionstart

当浏览器有非直接的文字输入时, compositionstart事件会以同步模式触发。

compositionend

当浏览器是直接的文字输入时, compositionend会以同步模式触发。


    


你可能感兴趣的:(JavaScript)