php7栏目介绍留言板开发相关的列表搜索

免费推荐:PHP7
当数据量上来的时候,要找到它们中的一条,单单翻页去查找是一件很困难的事,这是时候就需要用到数据的搜索,可以瞬间找到我们想要的数据,既可以模糊搜索也可以精准搜索。
在【分页】那一节我们已经做到了翻页,现在我们给这个列表加入搜索框进行搜索。

立即学习“PHP免费学习笔记(深入)”;
搜索姓名是“地方”的记录效果图
拿到任务的时候,如果没有设计图,自己脑子里要有个大概的想法,当然有经验了可以直接撸代码;还不好下手那就自己手动画一个(纸跟笔的少不了的)。万事俱备只欠动手撸码了。
$keyword,组装sql查询关键词语句"SELECT * FROM feedback WHERE name LIKE '%{$keyword}%'";,去执行sql语句或者相应数据返回前台呈现给用户。注:name LIKE '%{$keyword}%'" 意思是获取name字段中包含$keyword的记录集,两边的%百分号是指匹配任意类型和长度的字符,即模糊搜索,精准搜索去掉百分号即可。
无非就是开头的三步骤,稳稳的完成任务,看着是不是离全栈工程师又更近一步了。
结合课程开头的代码使用
老友记之PHP7留言板开发(步骤一)
老友记之PHP7留言板开发(步骤二)
老友记之PHP7留言板开发(步骤三)
<?php
include 'config.php';
$page = !empty($_GET['page'])?intval($_GET['page']):1;
$keyword = !empty($_GET['keyword'])?strip_tags($_GET['keyword']):'';
$pagesize = 1;
// 统计总记录数,便于计算出总页数
if(!empty($keyword)){
    $sql = "SELECT * FROM feedback WHERE name LIKE '%{$keyword}%'";
}else{
    $sql = "SELECT * FROM feedback";
}
$result = mysqli_query($mysqli, $sql);
$total = mysqli_affected_rows($mysqli);
$total_page = ceil($total/$pagesize); // 进一法取整获取总页数
// 开始分页查询,根据page计算偏移量
$offset = ($page - 1) * $pagesize;
if(!empty($keyword)){
    $sql = "SELECT * FROM feedback WHERE name LIKE '%{$keyword}%' LIMIT {$offset}, {$pagesize}";
}else{
    $sql = "SELECT * FROM feedback LIMIT {$offset}, {$pagesize}";
}
$result = mysqli_query($mysqli, $sql);
$lists = array();
while($rows = mysqli_fetch_array($result)){
    $lists[] = $rows;
}
?>
<!DOCTYPE html>
<html>
    <head>
        <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
        <title>列表带搜索功能_留言板_科科分享</title>
        <!-- 2.新建css样式文件并根据效果图编写css代码 -->
        <link rel="stylesheet" href="feedback.css">
        
    </head>
    <body>
        <!-- 工作区,呈现给用户看的 -->
        <!-- 1.开始搭建脚手架 -->
        <p class="container_box">
            <p class="up">
                <h3 class="title">留言板</h3>
                <h5 class="subtitle">LIST</h5>
            </p>
            <p class="down list">
                <p class="search">
                <form action="list.php">    
                关键词:<input type='text' name="keyword" />
                <input type="submit" value="去搜索">
                </form>
                </p>
                <ul>
                    <?php
                    foreach($lists as $item){
                    ?>
                    <li>姓名:<?php echo $item['name']?> 联系方式:<?php echo $item['contact']?> 内容:<?php echo $item['content']?></li>
                    <?php
                    }
                    ?>
                </ul>
                <p class="pages">
                    <ul>
                        <?php
                        for($p = 1; $p<=$total_page; $p++){
                        ?>
                        <li <?php echo ($page == $p)?'class="active"':'';?>><a href="?page=<?php echo $p?>&keyword=<?php echo $keyword?>"><?php echo $p?></a></li>
                        <?php
                        }
                        ?>
                    </ul>
                </p>
            </p>
        </p>
    </body>
</html关键词:like(喜欢,像...)
查询用户输入的关键词就是在数据库中查询用户喜欢的数据出来并呈现给用户。
本节结束,记得勤加练习,尽量手写代码。
如有内容错误或者疑惑记得下方评论区涂鸦!~
以上就是PHP7留言板开发之列表搜索的详细内容,更多请关注php中文网其它相关文章!
                        
                        PHP怎么学习?PHP怎么入门?PHP在哪学?PHP怎么学才快?不用担心,这里为大家提供了PHP速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!
                Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号