当前位置:   article > 正文

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

js oninput延时

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

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

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

<body>
    <input id='inputValue' oninput="inputValueChange()" />
</body>
<script>
    var timeoutID=0;
    function inputValueChange(){
        let inputValue = document.getElementById("inputValue").value;
        //空值不触发事件
        if(inputValue == '')
            return;
        clearTimeout(timeoutID); //两次输入时间小于500ms时 清除上一个延时器
        //设置新的延时器
        timeoutID = setTimeout(function(){  
           //ajax请求
            console.log(inputValue)
        },500);
    }
</script>
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  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会以同步模式触发。

<body>
    <input id='inputValue' oninput="inputValueChange()" />
</body>
<script>
    var cpFlag = false;
    var timeoutID=0;
    var input = document.getElementById("inputValue");
    
    function inputValueChange(){
        let inputValue = input.value;
        //空值不触发事件
        console.log(1);
        if(inputValue == '')
            return;
        if(cpFlag == true){
            return;
        }
        clearTimeout(timeoutID); //两次输入时间小于500ms时 清除上一个延时器
        //设置新的延时器
        timeoutID = setTimeout(function(){  
           //ajax请求
            console.log(inputValue)
        },500);
    }
    //监听中文输入开始
    input.addEventListener('compositionstart', function(){
        console.log("s");
        cpFlag = true;
    })
    //监听中文输入结束
    input.addEventListener('compositionend', function(){
        console.log("e")
        cpFlag = false;
    })
</script>
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20
  • 21
  • 22
  • 23
  • 24
  • 25
  • 26
  • 27
  • 28
  • 29
  • 30
  • 31
  • 32
  • 33
  • 34
  • 35
声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/小丑西瓜9/article/detail/556965
推荐阅读
相关标签
  

闽ICP备14008679号