php做站内搜索并高亮显示关键字

本文章介绍一篇较实用的文章关于php做站内搜索并高亮显示关键字,这个很多朋友直接利用preg_replace来操作,这是正确的哦,不过我觉得用str_replace更快一些哦,至于原因自己查查这两个函数的区别吧。

如何使用php做站内搜索并高亮显示关键字?代码如下:

  1. <?php 
  2.        require_once 'sqlTools.class.php';//封装类,可执行dql、dml语句 
  3.        $info=$_POST['info']; 
  4.        $sql="select name,password,email from user_500 where name like '%$info%' or password like '%$info%' or email like '%$info%'"
  5.        $sqlTools=new  SqlTools(); 
  6.        $res=$sqlTools->execute_dql($sql); 
  7.        while ($row=mysql_fetch_assoc($res)){ 
  8.               $row['name']=preg_replace("/($info)/i","<b style="color:red">1</b>",$row['name']); 
  9.               $row['password']=preg_replace("/($info)/i","<b style="color:red">1</b>",$row['password']); 
  10.               $row['email']=preg_replace("/($info)/i","<b style="color:red">1</b>",$row['email']); 
  11.               echo $row['name']."–>".$row['password']."–>".$row['email']."<br>"
  12.        }    
  13. ?> 

思路分析:将sql语句中包含的%$info%交给DBMS执行的时候,他会查找字段中含有变量$info的值的信息,

%$info—>查找以$info的值结束的信息

$info%—>查找以$info的值开头的信息

通过正则函数preg_replace()将搜索到的关键字高亮显示,比如:

$row['name']=preg_replace("/($info)/i","<b style="color:red">1</b>",$row['name']);

的意思是:通过POST方接收到的值$info替换为加上样式(红色加粗)的结果,并将结果重新赋给$row[‘name’]

如果要搜索多个关键字的话,可以对接收到值$info进行分割,比如$info_more=explode(" ",$info);//这种方式能对以空格隔开的关键字进行分割,再对分割后的结果挨个进行查询,同样,可以使用正则表达式函数进行替换工作,以高亮显示关键字,代码如下:

sqlTools.class.php的源代码:

  1. <?php 
  2.        class SqlTools{ 
  3.               private $host="localhost"
  4.               private $dbname="test"
  5.               private $dbuser="root"
  6.               private $dbpwd=""
  7.               private $conn
  8.               public function __construct(){ 
  9.                      $this->conn=mysql_connect($this->host,$this->dbuser,$this->dbpwd); 
  10.                      if(!$this->conn){ 
  11.                             die("连接数据库失败".mysql_error()); 
  12.                      } 
  13.                      mysql_select_db($this->dbname,$this->conn) or die("找不到该数据库".mysql_error()); 
  14.                      mysql_query("set names utf8"); 
  15.               } 
  16.               public function execute_dml($sql){ 
  17.                      $bool=mysql_query($sql); 
  18.                      if ($bool){ 
  19.                             if ($bool>0) { 
  20.                                    return 1; 
  21.                             }else
  22.                                    return 2; 
  23.                             } 
  24.                      }else { 
  25.                             return 0; 
  26.                      } 
  27.               } 
  28.               public function execute_dql($sql){ 
  29.                      $res=mysql_query($sql); 
  30.                      return $res
  31.               } 
  32.               public function close_conn(){ 
  33.                      mysql_close($this->conn); 
  34.               } 
  35.        } 
  36. ?>
波比源码 – 精品源码模版分享 | www.bobi11.com
1. 本站所有资源来源于用户上传和网络,如有侵权请邮件联系站长!
2. 分享目的仅供大家学习和交流,您必须在下载后24小时内删除!
3. 不得使用于非法商业用途,不得违反国家法律。否则后果自负!
4. 本站提供的源码、模板、插件等等其他资源,都不包含技术服务请大家谅解!
5. 如有链接无法下载、失效或广告,请联系管理员处理!
6. 本站资源售价只是赞助,收取费用仅维持本站的日常运营所需!
7. 本站源码并不保证全部能正常使用,仅供有技术基础的人学习研究,请谨慎下载
8. 如遇到加密压缩包,请使用WINRAR解压,如遇到无法解压的请联系管理员!

波比源码 » php做站内搜索并高亮显示关键字

86 评论

  1. order tadalis 20mg sale diclofenac us voltaren 100mg ca

  2. order provigil 200mg online cheap oral diamox 250mg acetazolamide oral

  3. order fosamax 70mg without prescription cost famotidine famotidine 40mg uk

  4. order generic molnupiravir 200 mg buy naproxen online buy prevacid 30mg generic

  5. generic medroxyprogesterone 5mg microzide brand order periactin online

  6. buy lasix 100mg for sale generic lasix buy plaquenil 200mg online cheap

  7. purchase lopressor pill metoprolol brand vardenafil 10mg without prescription

  8. purchase cialis oral inderal buy clopidogrel online

  9. buy zantac 150mg pills buy zantac pills order celebrex 100mg for sale

  10. buy sildenafil tablets cost sildenafil buy tadalafil 10mg pill

  11. sildenafil next day delivery usa buy lamictal generic buy lamotrigine 200mg for sale

  12. clarithromycin 500mg cheap buy biaxin 250mg buy antivert without prescription

  13. buy pioglitazone 15mg pill purchase viagra pills buy sildenafil 50mg without prescription

  14. gambling casino online casino world quick hits free online slots

  15. purchase altace for sale cost altace order etoricoxib 120mg for sale

  16. buy acetazolamide 250 mg generic diamox 250mg us buy imuran 50mg online

  17. order metformin 500mg generic metformin canada buy generic tamoxifen 10mg

发表评论

Hi, 如果你对这款模板有疑问,可以跟我联系哦!

联系站长
赞助VIP 享更多特权,建议使用 QQ 登录
喜欢我嘛?喜欢就按“ctrl+D”收藏我吧!♡