php+ajax实时输入自动搜索匹配的方法


Posted in PHP onDecember 26, 2014

本文实例讲述了php+ajax实输入自动搜索匹配的方法分享给大家供大家参考。具体分析如下:

第一种方法利用了jquery autocomplete,第二种使用了jquery ajax,其实两个都差不多.

最简单的办法我们就是直接使用jquery autocomplete方法了,如下在实例.

html中,代码如下:

<script src="/js/v2/jquery.input_complete.js" type="text/javascript" ></script> 

<link rel="stylesheet" href="/css/v2/jquery.input_complete.css" type="text/css" /> 

<script type="text/javascript"> 

  $(function(){ 

   $("#abcc").bigAutocomplete({width:176,data:[{title:"九龙仓世纪华府",result:"5976898"},{title:"九龙仓君玺",result:"5976896"},{title:"舟山朱家尖东沙度假村",result:"5976895"},{title:"广厦天都城爵士花园",result:"5976893"},{title:"绿城玉园",result:"5976892"},{title:"江南铭楼",result:"5976890"},{title:"世茂江滨花园",result:"14869"}],callback:function(data){ 

    $("#s_loupan").val(data.result); 

   }});    

  }) 

</script> 

<input type="text" id="abcc" class="sel_quy" autocomplete="off" />

本文目的是让 某个标题 带有 The 的不按字母t首字母搜索,而是按照第二个文字的首字母搜索.

比如 The Orbolg,按T的时候不显示,按O的时候才显示,下面是实现代码,我自己都晕晕的,测试是没有问题,代码如下:

public function gwquery(){  

    if($_POST){  

    $zm = $_POST['data'];  

    $wzm = $zm."%";  

    $b = M('Wpindexgw');  

    if($zm!="t"){//获取的首字母不是t的时候  

    $list1 = $b->where("gwstatus=1 and gwname like '%$zm%'")->order("time desc")->select();//查询  

    $narr =array();  

    foreach( $list1 as $key => $val){          

        $ct2 = explode(" ",$val['gwname']);//获取标题拆分成数组。  

         $szm=strtolower(substr($ct2[1],0,1));  //获取首字母 并且小写  

        if($ct2[0]=="The" && $szm==$zm){//如果第一个字符是The 并且第二个字母首字母和提交的相同,这里The 区分大小写。  

        $narr[] = $val; //写入数组  

        }     

    }  

    }else{      //处理首字母是T的时候    ,不希望第一个字数The 的显示在列表里。  

        $list1 = $b->where("gwstatus=1 and gwname like '$wzm'")->order("time desc")->select();  

    foreach( $list1 as $key => $val){          

        $ct2 = explode(" ",$val['gwname']);  

        if($ct2[0]=="The"){  

        $unnarr[] = $key;//获取符合条件的,要去掉的内容的数组标号。       

        }  

    }     

}  

    $list = $b->where("gwstatus=1 and gwname like '$wzm'")->order("time desc")->select();//正常的查询。  

    if($zm=="t"){//处理当首字母是t的时候 ,去掉上面查询得到的内容,也就是如果是The的时候 按T 不显示。  

    foreach($unnarr as $uval){  

        unset($list[$uval]);  

    }             

    }else{//按下的不是t的时候,要把第二个首字母符合的内容添加到正常查询的数组中。  

    if(!emptyempty($narr) && !emptyempty($list)){//带The 的符合条件正常 本身也不空的时候。  

    $list = array_merge($narr,$list);//合并数组。  

    }else if(emptyempty($list)){//正常查询为空。则看是否有带The开头的,有则合并  

    $list=array();  

    $list = array_merge($narr,$list);     

    }

    }  

    if($list){  

    $this->ajaxReturn($list,'success',1);  

    }else{  

        $this->error("Bestiary not found.");  

        }  

    }  

}

相比之前的代码,相差太多,代码如下:
public function gwquery1(){//之前备份。。  

    if($_POST){  

    $zm = $_POST['data'];  

    $wzm = $zm."%";  

    $b = M('Wpindexgw');  

    $list = $b->where("gwstatus=1 and gwname like '$wzm'")->order("time desc")->select();  

    //dump($list);  

    if($list){  

    $this->ajaxReturn($list,'success',1);  

    }else{  

        $this->error("Bestiary not found.");  

        }  

    }  

}

希望本文所述对大家的php程序设计有所帮助。

PHP 相关文章推荐
php计算两个日期时间差(返回年、月、日)
Jun 19 PHP
ThinkPHP模板判断输出Defined标签用法详解
Jun 30 PHP
超详细的php用户注册页面填写信息完整实例(附源码)
Nov 17 PHP
PHP中的session安全吗?
Jan 22 PHP
php实现爬取和分析知乎用户数据
Jan 26 PHP
jQuery+php简单实现全选删除的方法
Nov 28 PHP
php 三元运算符实例详细介绍
Dec 15 PHP
thinkPHP5.0框架应用请求生命周期分析
Mar 25 PHP
PHP使用星号替代用户名手机和邮箱的实现代码
Feb 07 PHP
PHP随机数函数rand()与mt_rand()的讲解
Mar 25 PHP
php实现文件上传基本验证
Mar 04 PHP
php字符串倒叙
Apr 01 PHP
windows下配置php5.5开发环境及开发扩展
Dec 25 #PHP
PHP中require和include路径问题详解
Dec 25 #PHP
Yii框架调试心得--在页面输出执行sql语句
Dec 25 #PHP
Web程序工作原理详解
Dec 25 #PHP
php更新mysql后获取改变行数的方法
Dec 25 #PHP
php常见的魔术方法详解
Dec 25 #PHP
php利用scws实现mysql全文搜索功能的方法
Dec 25 #PHP
You might like
40个迹象表明你还是PHP菜鸟
2008/09/29 PHP
php ucwords() 函数将字符串中每个单词的首字符转换为大写(实现代码)
2016/05/12 PHP
PHP自定义图片缩放函数实现等比例不失真缩放的方法
2016/08/19 PHP
mysql alter table命令修改表结构实例详解
2016/09/24 PHP
在IE下获取object(ActiveX)的Param的代码
2009/09/15 Javascript
了解jQuery技巧来提高你的代码
2010/01/08 Javascript
jQuery修改CSS伪元素属性的方法
2014/07/30 Javascript
使用jquery清空、复位整个输入域
2015/04/02 Javascript
JS实现显示带倒影的图片横排居中放大展示特效实例【测试可用】
2016/08/23 Javascript
JS出现失效的情况总结
2017/01/20 Javascript
初探js和简单隐藏效果的实例
2017/11/23 Javascript
JavaScript中使用import 和require打包后实现原理分析
2018/03/07 Javascript
详解vue2.0监听属性的使用心得及搭配计算属性的使用
2018/07/18 Javascript
Bootstrap Table列宽拖动的方法
2018/08/15 Javascript
jQuery实现获取及设置CSS样式操作详解
2018/09/05 jQuery
vue的keep-alive中使用EventBus的方法
2019/04/23 Javascript
分享一个vue项目“脚手架”项目的实现步骤
2019/05/26 Javascript
[01:17:47]TNC vs VGJ.S 2018国际邀请赛小组赛BO2 第一场 8.18
2018/08/19 DOTA
跟老齐学Python之赋值,简单也不简单
2014/09/24 Python
Python入门之modf()方法的使用
2015/05/15 Python
使用 Python 遍历目录树的方法
2020/02/29 Python
python输出第n个默尼森数的实现示例
2020/03/08 Python
浅谈python处理json和redis hash的坑
2020/07/16 Python
详解Python 中的容器 collections
2020/08/17 Python
通俗易懂了解Python装饰器原理
2020/09/17 Python
Python+MySQL随机试卷及答案生成程序的示例代码
2021/02/01 Python
深入解析HTML5中的Blob对象的使用
2015/09/08 HTML / CSS
美国婴儿服装购物网站:Gerber Childrenswear
2020/05/06 全球购物
俄罗斯品牌服装在线商店:VIPAVENUE
2020/08/10 全球购物
《四季》教学反思
2014/04/08 职场文书
《少年王冕》教学反思
2014/04/11 职场文书
2014年管理工作总结
2014/11/22 职场文书
2014年变电站工作总结
2014/12/19 职场文书
护士自我推荐信范文
2015/03/24 职场文书
新闻通讯稿范文
2015/07/22 职场文书
Nginx 过滤静态资源文件的访问日志的实现
2021/03/31 Servers