keyup模糊搜索提示框实现原理

2023-10-27 20:32

本文主要是介绍keyup模糊搜索提示框实现原理,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

http://www.520ued.com/article/53881dccb992a7c43f5c2038


2014-05-30


keyup模糊搜索提示框实现原理

    大家在使用百度,google搜索的时候,出现的模糊搜索框应该很有感触,因为确实很方便,不只是搜索引擎需要用到这个模糊搜索框的提示功能,想很多购物网站,如果淘宝,天猫,只要规模稍微大点的网站,由于内容较多的时候,都会有搜索功能,当然如果搜索功能能带模糊搜索提示框的话,我想对用户体验将会是很大的提高。怎么做才能高效的实现只一个功能呢,今天我就用jquery来给大家做这样一个功能。

    首先我们来看一下大部分人会用的写法:

    如果你觉得这种写法来实现这个功能,那就太不明智了,因为他非常的损耗性能,因为这个事件键盘弹起来的时候就会执行一次请求:

    上面DEMO中当你们输入汉字的时候,文字拼音还没打完的时候,右边的提示框就已经开始执行你的请求了,这样一来,我们在打汉字的时候就文字还没打出来,就已经在执行ajax去服务器请求了,这样是极其损害性能的。

    解决这个问题的办法我们可以给keyup事件加上一个延迟,等用户输入完一个完整的关键词的时候我们在进行请求,请看接下来的代码:

  1. var lastTime;
  2. $("#search").keyup(function(event){
  3.     //我们可以用jQuery的event.timeStamp来标记时间,这样每次的keyup事件都会修改lastTime的值,lastTime必需是全局变量
  4.     lastTime = event.timeStamp;
  5.     setTimeout(function(){
  6.         //如果时间差为0,也就是你停止输入0.5s之内都没有其它的keyup事件产生,这个时候就可以去请求服务器了
  7.         if(lastTime - event.timeStamp == 0){
  8.             /*
  9.              在这里可以执行ajax请求
  10.              */
  11.             var $val = $("#search").val();
  12.             $("#tip").html($val);
  13.         }
  14.     },500);
  15. });

    大家测试下上面这个DEMO效果,在你输入完一个完整的词汇前他是不会发送请求的,其实上面的代码,不仅仅是靠setTimeout做了延迟,如果你写了延迟也是错的,因为他只是延迟了发送数据,即时你词汇打出来了之后,他还是会去执行kkkk这个数据的,关键的一个属性是jquery的event.timeStamp,我们来看下jquery api 提供的解释吧。

通过在代码中获得两个点之间的 event.timeStamp 值,并给出差值来分析事件的性能,此属性是很有用的。如果只是要确定当前的时间内的事件处理程序,使用(new Date).getTime()来代替。 
注意: 有一个 
bug open since 2004, 这个值是不正确填充在Firefox  它是不可能知道事件的时间,在该浏览器中创建。

  1. <!DOCTYPE html>
  2. <html>
  3. <head>
  4. <style>
  5. div { height: 100px; width: 300px; margin: 10px;
  6.     background-color: #ffd; overflow: auto; }
  7. </style>
  8. <script src="http://code.jquery.com/jquery-latest.js"></script>
  9.     </head>
  10.     <body>
  11.     <div>Click.</div>
  12.     <script>
  13. var last, diff;
  14. $('div').click(function(event) {
  15.     if ( last ) {
  16.         diff = event.timeStamp - last
  17.         $('div').append('time since last event: ' + diff + '<br/>');
  18.     } else {
  19.         $('div').append('Click again.<br/>');
  20.     }
  21.     last = event.timeStamp;
  22. });
  23. </script>
  24. </body>
  25. </html>


只要理解了Jquery里面的这个event.timeStamp的用法,理解这个功能的实现方法就没什么问题了。

转载请注明来自 520UEDhttp://www.520ued.com/article/53881dccb992a7c43f5c2038


这篇关于keyup模糊搜索提示框实现原理的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/288218

相关文章

SpringBoot全局域名替换的实现

《SpringBoot全局域名替换的实现》本文主要介绍了SpringBoot全局域名替换的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一... 目录 项目结构⚙️ 配置文件application.yml️ 配置类AppProperties.Ja

Python实现批量CSV转Excel的高性能处理方案

《Python实现批量CSV转Excel的高性能处理方案》在日常办公中,我们经常需要将CSV格式的数据转换为Excel文件,本文将介绍一个基于Python的高性能解决方案,感兴趣的小伙伴可以跟随小编一... 目录一、场景需求二、技术方案三、核心代码四、批量处理方案五、性能优化六、使用示例完整代码七、小结一、

Java实现将HTML文件与字符串转换为图片

《Java实现将HTML文件与字符串转换为图片》在Java开发中,我们经常会遇到将HTML内容转换为图片的需求,本文小编就来和大家详细讲讲如何使用FreeSpire.DocforJava库来实现这一功... 目录前言核心实现:html 转图片完整代码场景 1:转换本地 HTML 文件为图片场景 2:转换 H

C#使用Spire.Doc for .NET实现HTML转Word的高效方案

《C#使用Spire.Docfor.NET实现HTML转Word的高效方案》在Web开发中,HTML内容的生成与处理是高频需求,然而,当用户需要将HTML页面或动态生成的HTML字符串转换为Wor... 目录引言一、html转Word的典型场景与挑战二、用 Spire.Doc 实现 HTML 转 Word1

C#实现一键批量合并PDF文档

《C#实现一键批量合并PDF文档》这篇文章主要为大家详细介绍了如何使用C#实现一键批量合并PDF文档功能,文中的示例代码简洁易懂,感兴趣的小伙伴可以跟随小编一起学习一下... 目录前言效果展示功能实现1、添加文件2、文件分组(书签)3、定义页码范围4、自定义显示5、定义页面尺寸6、PDF批量合并7、其他方法

SpringBoot实现不同接口指定上传文件大小的具体步骤

《SpringBoot实现不同接口指定上传文件大小的具体步骤》:本文主要介绍在SpringBoot中通过自定义注解、AOP拦截和配置文件实现不同接口上传文件大小限制的方法,强调需设置全局阈值远大于... 目录一  springboot实现不同接口指定文件大小1.1 思路说明1.2 工程启动说明二 具体实施2

Python实现精确小数计算的完全指南

《Python实现精确小数计算的完全指南》在金融计算、科学实验和工程领域,浮点数精度问题一直是开发者面临的重大挑战,本文将深入解析Python精确小数计算技术体系,感兴趣的小伙伴可以了解一下... 目录引言:小数精度问题的核心挑战一、浮点数精度问题分析1.1 浮点数精度陷阱1.2 浮点数误差来源二、基础解决

Java实现在Word文档中添加文本水印和图片水印的操作指南

《Java实现在Word文档中添加文本水印和图片水印的操作指南》在当今数字时代,文档的自动化处理与安全防护变得尤为重要,无论是为了保护版权、推广品牌,还是为了在文档中加入特定的标识,为Word文档添加... 目录引言Spire.Doc for Java:高效Word文档处理的利器代码实战:使用Java为Wo

Java实现远程执行Shell指令

《Java实现远程执行Shell指令》文章介绍使用JSch在SpringBoot项目中实现远程Shell操作,涵盖环境配置、依赖引入及工具类编写,详解分号和双与号执行多指令的区别... 目录软硬件环境说明编写执行Shell指令的工具类总结jsch(Java Secure Channel)是SSH2的一个纯J

使用Python实现Word文档的自动化对比方案

《使用Python实现Word文档的自动化对比方案》我们经常需要比较两个Word文档的版本差异,无论是合同修订、论文修改还是代码文档更新,人工比对不仅效率低下,还容易遗漏关键改动,下面通过一个实际案例... 目录引言一、使用python-docx库解析文档结构二、使用difflib进行差异比对三、高级对比方