Hướng dẫn tạo website tin tức phần 26: Tạo trang tìm kiếm

Hướng dẫn tạo website tin tức phần 26: Tạo trang tìm kiếm là vấn đề được nhiều lập trình viên quan tâm, bởi những kiến thức trên trường lớp là không đủ, vì vậy bài Hướng dẫn tạo website tin tức phần 26: Tạo trang tìm kiếm sẽ chia sẻ tới bạn nhiều thông tin hữu ích

Mọi người vẫn hỏi tôi về việc học lập trình nói chung và PHP nói riêng có cần năng khiếu hay quá khó để tiếp cận hay không. Thì tôi có thể trả lời rằng, học lập trình cũng như việc bạn học tiếng Anh hay bất kỳ một ngôn ngữ khác, bởi lập trình...là ngôn ngữ của máy tính, để máy tính đọc và máy tính thực hiện theo yêu cầu của mình, bạn thích là học được.

Xin chào tất cả các bạn, chào mừng các bạn đã quay trở lại với series hướng dẫn xây dựng trang tin tức cơ bản tại Hoidapcode. Trong bài học trước, chúng ta đã cùng nhau xây dựng trang hiển thị nội dung bài viết. Hôm nay, mình sẽ hướng dẫn các bạn xây dựng chức năng tìm kiếm cho ứng dụng này. Chúng ta bắt đầu ngay thôi!

1. Xây dựng template hộp tìm kiếm

Trong bài 22, chúng ta đã xây dựng template cho hộp tìm kiếm rồi, các bạn có thể chạy project rồi click vào icon tìm kiếm, một hộp thoại sẽ mở ra như hình bên dưới:

Tiếp theo chúng ta sẽ xây dựng trang để show kết quả tìm kiếm.

2. Viết trang hiển thị kết quả tìm kiếm

Các bạn mở file templates/search.php lên và copy nội dung này vào:

<div class="container">
    <div class="row">
        <h3>Tìm kiếm</h3>
        <?php
 
        // Lấy tham số từ khóa tìm kiếm
        $s = trim(htmlspecialchars(addslashes($_GET['s'])));
 
        if ($s) {
            // Lấy số hàng trong table
            $sqlGetCountPost = "SELECT id_post FROM posts WHERE status = '1' AND title LIKE '%$s%' OR keywords LIKE '%$s%' OR descr LIKE '%$s%'";
            $countPost = $db->num_rows($sqlGetCountPost);
 
            // Lấy tham số trang
            if (isset($_GET['p'])) {
              $page = trim(htmlspecialchars(addslashes($_GET['p'])));
 
              if (preg_match('/\d/', $page)) {
                $page = $page;
              } else {
                $page = 1;
              }
            } else {
              $page = 1;
            }
 
            $limit = 20; // Giới hạn số bài viết hiển thị trong 1 trang
            $totalPage = ceil($countPost / $limit); // Tổng số trang sau khi tính toán
                 
            // Validate tham số page    
            if ($page > $totalPage) {
              $page = $totalPage;
            } else if ($page < 1) {
              $page = 1;
            }
               
            $start = ($page - 1) * $limit;
 
            $sql_get_news = "SELECT * FROM posts WHERE status = '1' AND title LIKE '%$s%' OR keywords LIKE '%$s%' OR descr LIKE '%$s%' ORDER BY id_post DESC LIMIT $start, $limit";
            if ($db->num_rows($sql_get_news)) {
                foreach ($db->fetch_assoc($sql_get_news, 0) as $data_post) {
                    echo '
                        <div class="col-md-3">
                            <div class="thumbnail">
                                <a href="' . $_DOMAIN . $data_post['slug'] . '-' . $data_post['id_post'] . '.html">
                                    <img src="' . $data_post['url_thumb'] . '">
                                </a>
                                <div class="caption">
                                    <h3><a href="' . $_DOMAIN . $data_post['slug'] . '-' . $data_post['id_post'] . '.html">' . $data_post['title'] . '</a></h3>
                                    <p>' . $data_post['descr'] . '</p>
                                </div>
                            </div>
                        </div>
                    ';
                }
 
                echo '</div>';
 
                echo '
                    <div class="btn-toolbar" role="toolbar">
                        <div class="btn-group">
                ';
 
                # Pagination button
                if ($page > 1 && $totalPage > 1) {
                    echo '
                        <a href="' . $_DOMAIN . ($page - 1 ) . '" class="btn btn-default">
                            <span class="glyphicon glyphicon-chevron-left"></span>
                        </a>
                    ';
                }
                
                for ($i = 1; $i <= $totalPage; $i++) {
                    if ($i == $page){
                        echo '<a class="btn btn-primary">' . $i . '</a>';
                    } else {
                        echo '
                            <a href="' . $_DOMAIN . $i . '" class="btn btn-default">
                                ' . $i . '
                            </a>
                        ';
                    }
                }
                
                if ($page < $totalPage && $totalPage > 1) {
                    echo '
                        <a href="' . $_DOMAIN . ($page + 1 ) . '" class="btn btn-default">
                            <span class="glyphicon glyphicon-chevron-right"></span>
                        </a>
                    ';
                }
 
                echo '
                        </div>
                    </div>
                ';
            } else {
                echo '<div class="well well-lg">Không tìm thấy kết quả nào.</div>';
            }
        } else {
            echo '<div class="alert alert-danger">Vui lòng nhập từ khóa tìm kiếm.</div>';
        }
 
        ?>
    </div>
</div> 

Để có thể tìm kiếm, mình đã sử dụng câu lệnh LIKE trong SQL, câu lệnh này có chức năng kiểm tra $s gần giống hoặc giống với dữ liệu trong table posts hay không? Ở đây mình chọn lọc theo field title, keywordsdescr:title LIKE '%$s%' OR keywords LIKE '%$s%' OR descr LIKE '%$s%'

Nếu bạn nào không biết về lệnh LIKE có thể tham khảo bài viết này.

Ok, giờ các bạn lưu lại và chạy thử xem kết quả như mong muốn chưa nhé!

3. Lời kết

Kết thúc bài này ở đây, bài này tương đối ngắn nên mình cần các bạn nắm được câu lệnh SQL để làm một chức năng tìm kiếm đơn giản. Qua bài sau, mình sẽ hướng dẫn các bạn xây dựng các trang còn lại và clear source cho ứng dụng. Nếu có thắc mắc gì các bạn cứ comment bên dưới hoặc đăng trên group kèm theo link bài viết để được hỗ trợ sớm nhất. Cảm ơn các bạn đã theo dõi, chúc các bạn thành công!

Hy vọng với bài viết về Hướng dẫn tạo website tin tức phần 26: Tạo trang tìm kiếm đã giải đáp giúp bạn phần nào về kiến thức lập trình PHP. Như tôi đã nói, ngôn ngữ lập trình không quan trọng bằng tư duy giải thuật, tư duy logic để giải quyết vấn đề.

Với những năm trước đây, lập trình viên là một cái nghề khó và kén chọn người học, đồng nghĩa với việc thu nhập hàng tháng của các lập trình viên luôn cao. Còn những năm gần đây, thì lập trình là môn học phổ thông, và ai cũng nên học một ngôn ngữ lập trình nào đó.

Nếu bạn còn bất kỳ câu hỏi nào trong việc học lập trình online, hãy gửi yêu cầu cho tôi qua email hoidapcode.com@gmail.com hoặc để lại comment bên dưới, tôi sẽ giải đáp trong vòng 24 giờ!

Blog hoidapcode.com là blog được tổng hợp tự động các bài học, thông tin về lập trình trên mạng internet. Nếu bạn có ý kiến hoặc đóng góp về bài viết này, hãy liên hệ với tôi!