PHP实现多关键字加亮功能


Posted in PHP onOctober 21, 2016

本文主要介绍的是PHP实现多关键字加亮功能,可以实现在搜索的时候进行高亮提醒,具体实现代码如下:

项目结构:

PHP实现多关键字加亮功能

搜索结果:  高亮显示

PHP实现多关键字加亮功能

项目所需数据库结构:

PHP实现多关键字加亮功能

实现代码:

conn.php

<?php 
$conn = @ mysql_connect("localhost", "root", "") or die("数据库链接错误"); 
mysql_select_db("form", $conn); 
mysql_query("set names 'gbk'"); 
?>

searchAndDisplayWithColor.php

<?php 
include 'conn.php'; 
?> 
<table width=500 align="center"> 
  <form action="" method="get"> 
  <tr> 
   <td>关键字:<input type="text" name="keyWord" /> 
   <input type="submit" value="搜索" /></td> 
  </tr> 
  </form> 
 </table> 
 
 <table width=500 border="0" align="center" cellpadding="5" 
  cellspacing="1" bgcolor="#add3ef"> 
  <?php 
  //关键字不为空的时候才执行相关搜索 
  if($_GET['keyWord']){ 
  //用空格符把关键字分割开 
  $key=explode(' ', $_GET[keyWord]); 
  $sql="select * from message where title like '$key[0]' or title like '$key[1]' or content like '$key[0]' or content like '%$key[1]%'"; 
  $query=mysql_query($sql); 
  while ($row=mysql_fetch_array($query)){ 
   //替换关键字,并且把关键字高亮显示 
   $row[title]=preg_replace("/$key[0]/i", "<font color=red><b>$key[0]</b></font>", $row[title]); 
   $row[title]=preg_replace("/$key[0]/i", "<font color=red><b>$key[1]</b></font>", $row[title]); 
   $row[content]=preg_replace("/$key[0]/i", "<font color=red><b>$key[0]</b></font>", $row[content]); 
   $row[content]=preg_replace("/$key[1]/i", "<font color=red><b>$key[1]</b></font>", $row[content]); 
   ?> 
 
  <tr bgcolor="#eff3ff"> 
   <td>标题:<font color="black"><?=$row[title]?></font> 用户:<font color="black"><?=$row[user] ?></font> 
   <div align="right"><a href="preEdit.php?id=<?=$row[id]?>">编辑</a>  |  <a 
    href="delete.php?id=<?=$row[id]?>">删除</a></div> 
   </td> 
  </tr> 
  <tr bgColor="#ffffff"> 
   <td>内容:<?=$row[content]?></td> 
  </tr> 
  <tr bgColor="#ffffff"> 
   <td> 
   <div align="right">发表日期:<?=$row[lastdate]?></div> 
   </td> 
  </tr> 
  <?php } 
  } 
  ?> 
 </table>

说明:在这个小程序中,有一点不足之处在于,只能同时搜索两个关键字,并且中间用空格" "隔开,如果只是搜索一个关键字,如:"大"

显示的时候会出现乱码 ……^|_|^,这是由于下面代码的结果:

//用空格符把关键字分割开 
 $key=explode(' ', $_GET[keyWord]);

希望本文所述对你有所帮助,PHP实现多关键字加亮功能内容就给大家介绍到这里了。希望大家继续关注我们的网站!想要学习php可以继续关注本站。

PHP 相关文章推荐
新安装的MySQL数据库需要注意的安全知识
Jul 30 PHP
基于PHP选项与信息函数的使用详解
May 10 PHP
浅析PHP原理之变量分离/引用(Variables Separation)
Aug 09 PHP
Yii扩展组件编写方法实例分析
Jun 29 PHP
分享ThinkPHP3.2中关联查询解决思路
Sep 20 PHP
Joomla数据库操作之JFactory::getDBO用法
May 05 PHP
Yii全局函数用法示例
Jan 22 PHP
thinkPHP5.0框架安装教程
Mar 25 PHP
php删除一个路径下的所有文件夹和文件的方法
Feb 07 PHP
PHP面向对象五大原则之里氏替换原则(LSP)详解
Apr 08 PHP
PHP+mysql实现的三级联动菜单功能示例
Feb 15 PHP
详解php中curl返回false的解决办法
Mar 18 PHP
PHP实现Google plus的好友拖拽分组效果
Oct 21 #PHP
PHP与服务器文件系统的简单交互
Oct 21 #PHP
微信公众号开发客服接口实例代码
Oct 21 #PHP
PHP抓取远程图片(含不带后缀的)教程详解
Oct 21 #PHP
PHP Header用于页面跳转时的几个注意事项
Oct 21 #PHP
phpcms中的评论样式修改方法
Oct 21 #PHP
PHP+jquery+CSS制作头像登录窗(仿QQ登陆)
Oct 20 #PHP
You might like
深入解析php模板技术原理【一】
2008/01/10 PHP
php中随机函数mt_rand()与rand()性能对比分析
2014/12/01 PHP
为PHP5.4开启Zend OPCode缓存
2014/12/26 PHP
解读PHP中上传文件的处理问题
2016/05/29 PHP
PHP读书笔记整理_结构语句详解
2016/07/01 PHP
PHP实现模拟http请求的方法分析
2017/12/20 PHP
css图片自适应大小
2007/11/28 Javascript
(jQuery,mootools,dojo)使用适合自己的编程别名命名
2010/09/14 Javascript
详解JavaScript中的异常处理方法
2015/06/16 Javascript
浅析ES6的八进制与二进制整数字面量
2016/08/30 Javascript
微信小程序 免费SSL证书https、TLS版本问题的解决办法
2016/12/14 Javascript
简单的渐变轮播插件
2017/01/12 Javascript
JavaScript中的工厂函数(推荐)
2017/03/08 Javascript
JS按钮闪烁功能的实现代码
2017/07/21 Javascript
vue封装第三方插件并发布到npm的方法
2017/09/25 Javascript
js获取对象,数组所有属性键值(key)和对应值(value)的方法示例
2019/06/19 Javascript
js计时事件实现圆形时钟
2020/03/25 Javascript
Vue实现多标签选择器
2019/11/28 Javascript
Node使用koa2实现一个简单JWT鉴权的方法
2021/01/26 Javascript
JS实现点击掉落特效
2021/01/29 Javascript
python  Django中的apps.py的目的是什么
2018/10/15 Python
Python实现的简单线性回归算法实例分析
2018/12/26 Python
详解python配置虚拟环境
2019/04/08 Python
从一次项目重构说起CSS3自定义变量在项目的使用方法
2021/03/01 HTML / CSS
html5的localstorage详解
2017/05/09 HTML / CSS
西班牙拥有最佳品牌的动物商店:Animalear.com
2018/01/05 全球购物
波兰最大的度假胜地和城市公寓租赁运营商:Sun & Snow
2018/10/18 全球购物
NULL是什么,它是怎么定义的
2015/05/09 面试题
校长就职演讲稿
2014/01/06 职场文书
租赁意向书范本
2014/04/01 职场文书
房产买卖委托公证书
2014/04/04 职场文书
网聊搭讪开场白
2015/05/28 职场文书
毕业生入职感言
2015/07/31 职场文书
2016国庆节67周年红领巾广播稿
2015/12/18 职场文书
Redis高可用集群redis-cluster详解
2022/03/20 Redis
windows server2008 开启端口的实现方法
2022/06/25 Servers