关于 input 输入搜索的优化

很多时候我们都会利用 input 的 change 事件做搜索功能,如果触发 change 事件不做处理就直接去请求数据或者处理数据会做很多次操作,所以我们在 change 事件里面需要做个处理减少数据的请求或处理次数。

    var searchTimeout,
        delayTime = 400,
        submitSearch = function() {
            // do something ...
        };

    // 搜索
    $(searchInput).change(function () {
        // 存在定时器则清除定时器
        !!searchTimeout && clearTimeout(searchTimeout);
        // 重新设置定时器
        searchTimeout = setTimeout(submitSearch, delayTime);
    });

思路就是利用定时器做个延迟的搜索,这样输入相隔时间小于 delayTime 的时候不会去处理搜索,当输入完成再去处理搜索。

©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容