Bài 13: Delay the keyup event for jquery ajax

DOWNLOAD DEMO

Có thể nói ajax là một kỹ thuật được ứng dụng rất rộng rãi trong các ứng dụng web vì sự mượt mà của nó, nhất là kết hợp với các hiệu ứng jquery. Nhưng để xử lý tiến trình ajax thật sự rất mơ hồ với những bạn mới làm quen với ajax. Một ví dụ điển hình là xây dựng chức năng search cho sự kiện keyup event, nếu ta nhập dữ liệu liên tục thì nó sẽ gửi request liên tục lên server, điều này  không hay lắm, thay vào đó ta sẽ gửi một request cuối cùng (ký tự cuối cùng nhập vào sẽ gửi ajax). Đây chính là kỹ thuật mà ta sẽ tìm hiểu trong bài này với tên gọi delay keyup event.

Trước khi vào vấn đề chính ta sẽ tạo một số file trong quá trình xử lý đã nhé.

1. Tạo các file xử lý liên quan

Tạo file result.php: File này có nhiệm vụ là nhận nội dung cần tìm và trả về kết quả, nhưng để đơn giản không có sử dụng database thì tôi sẽ trả về kết quả của chuỗi nhận vào, nội dung như sau:

<?php
echo isset($_GET['title']) ? $_GET['title'] : '';
?>

Tạo file index.php: File này hiển thị input#title nhập dữ liệu tìm kiếm, một thẻ div#result dùng để hiển thị kết quả trả về, một đoạn mã script trong đó có sự kiện keyup. Và đương nhiên là không thể thiếu đoạn code import file jquery vào.

<!DOCTYPE html>
<html>
    <head>
        <title>Delay the keyup event for jquery ajax</title>
        <meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
        <meta name="robots" content="noindex,nofollow"/>
        <script language="javascript" src="http://code.jquery.com/jquery-2.0.0.min.js"></script>
        <script language="javascript">
        
        $('#title').keyup(function()
        {
            // Nội dung search
        });
        
        </script>
    </head>
    <body>
        <a href="http://freetuts.net" title="Học lập trình online">Về trang chủ</a> <br/> <hr/>
        <input type="text" id="title" value=""/>
        <hr/>
        <div id="result"></div>
    </body>
</html>

Note: Nội dung trong bài có sử dụng ajax, nếu bạn chưa biết thì xem bài tìm hiểu ajax là gì.

2. Không sử dụng delay keyup event để gửi ajax

Cách này thì rất thông thường, ta chỉ cần bắt sự kiện keyup và lấy nội dung, sau đó gửi ajax.

$('#title').keyup(function()
{
    var data = {
        title : $('#title').val()
    };
    $.ajax({
        type : 'get',
        dataType : 'text',
        data : data,
        url : 'result.php',
        success : function (result){
            $('#result').html(result);
        }
    });
});

Nhược điểm của cách này là ajax sẽ gửi liên tục, mỗi khi nhập một ký tự vào nó sẽ gửi ajax nên sẽ tốn tài nguyên hệ thống và đôi khi hiển thị kết quả trả về lệch nhau do request trước trả kết quả về sau.  Với cách này tôi có viết một bài tương tự đó là bài Search Ajax Autocomplete.

3. Kỹ thuật Delay the keyup event for jquery ajax

Trước tiên bạn phải biết qua hàm setTimeout trong javascript dùng để thiết lập thời gian chạy một action nào đó và hàm clearTimeout dùng để bỏ đi sự kiện mà ta đã xử lý ở hàm setTimeout.

Ví dụ:

// Thiết lập trong thời gian 5 giây tới sẽ chạy đoạn code 
// alert lên chuỗi 123
var timeout = setTimeout(function(){
    alert('123');
}, 5000);


// Clear đi đói tượng timeout, lúc này đoạn code 
// alert sẽ không thực hiện được
clearTimeout(timeout);

Bây giờ ta sẽ ứng dụng 2 hàm này để thiết lập delay keyup event ajax:

Ý tưởng như sau, ở mỗi sự kiện keyup ta sẽ không gửi ajax liền mà ta sẽ dùng hàm setTimeout để thiết lập 1 giây sau mới gửi ajax tiếp, đồng thời trước khi thực hiện setTimeout thì ta sẽ dùng hàm clearTimeout để xóa đi những gì mà ta thiết lập trước đó. Như vậy khi ta gõ những ký tự gần nhau trong khoảng thời gian dưới 1 giây thì nó sẽ không gửi đi, chi khi nào ta dừng ko gõ thì 1 giây sau ajax sẽ được thực hiện. Đoạn code như sau:

// Delay the keyup event for jquery ajax
$(document).ready(function()
{
    // Khai báo đối tượng timeout để dùng cho hàm
    // clearTimeout
    var timeout = null;

    // Sự kiện keyup
    $('#title').keyup(function()
    {
        // Xóa đi những gì ta đã thiết lập ở sự kiện 
        // keyup của ký tự trước (nếu có)
        clearTimeout(timeout);

        // Sau khi xóa thì thiết lập lại timeout
        timeout = setTimeout(function ()
        {
            // Lấy nội dung search
            var data = {
                title : $('#title').val()
            };

            // Gửi ajax search
            $.ajax({
                type : 'get',
                dataType : 'text',
                data : data,
                url : 'result.php',
                success : function (result){
                    $('#result').html(result);
                }
            });
        }, 1000);
    });
});

Qua phần comment tôi đã giải thích rõ rồi tôi không giải thích gì thêm. Hãy chú ý đoạn code jquery ajax rất quan trọng, các bạn chỉ cần đọc code, xem demo và download về coi sẽ hiểu ra được vấn đề rất dễ dàng.

Và đây là hình hiển thị thành quả của chúng ta.

4. Lời kết

Khi làm việc với ajax ta sử dụng những mẹo rất nhỏ để áp dụng vào thì tiến trình xử lý sẽ rất là mượt và đáp ứng được yêu cầu của hệ thống. Như ví dụ trên không phải là một thứ gì to tác mà chỉ là một kỹ thuật nho nhỏ với tên gọi Delay the keyup event for jquery ajax rất đơn giản mà hiệu quả.

Cũng còn có nhiều cách giải quyết vấn đề này nên nếu bạn có cách nào hay thì hãy chia sẻ cho mọi người nhé.

Hãy để lại link bài viết gốc khi chia sẻ bài viết này, mình sẽ report DMCA với những website lấy nội dung mà không để nguồn hoặc copy bài với số lượng lớn.

Nguồn: freetuts.net

Profile photo of adminTheHalfHeart

TheHalfHeart

Có sở thích viết tuts nên đã từng tham gia viết ở một số diễn đàn, đến năm 2014 mới có điều kiện sáng lập ra freetuts.net. Sinh năm 90 và có 1 vợ 2 con, thích ca hát và lập trình.

ĐĂNG BÌNH LUẬN: Đăng câu hỏi trên Group Facebook để được hỗ trợ nhanh nhất.