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

在开发中会经常碰到要求监测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. 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>
  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值