1. ホーム
  2. jquery

[解決済み] jQueryのDataTables。3文字入力されるか、ボタンがクリックされるまで検索を遅らせる。

2023-04-07 08:06:04

質問

3文字入力後に検索を開始するオプションはありますか?

私は、20,000 のエントリを表示する同僚のために PHP スクリプトを書きましたが、彼らは、単語を入力するときに、最初の数文字がすべてをフリーズさせる原因となると不平を言いました。

代替案は、文字入力ではなく、ボタンをクリックすることによって検索を開始するようにすることです。

以下は私の現在のコードです。

$("#my_table").dataTable( {
        "bJQueryUI": true,
        "sPaginationType": "full_numbers",
        "bAutoWidth": false,
        "aoColumns": [
                /* qdatetime */   { "bSearchable": false },
                /* id */          null,
                /* name */        null,
                /* category */    null,
                /* appsversion */ null,
                /* osversion */   null,
                /* details */     { "bVisible": false },
                /* devinfo */     { "bVisible": false, "bSortable": false }
        ],
        "oLanguage": {
                "sProcessing":   "Wait please...",
                "sZeroRecords":  "No ids found.",
                "sInfo":         "Ids from _START_ to _END_ of _TOTAL_ total",
                "sInfoEmpty":    "Ids from 0 to 0 of 0 total",
                "sInfoFiltered": "(filtered from _MAX_ total)",
                "sInfoPostFix":  "",
                "sSearch":       "Search:",
                "sUrl":          "",
                "oPaginate": {
                        "sFirst":    "<<",
                        "sLast":     ">>",
                        "sNext":     ">",
                        "sPrevious": "<"
                },
                "sLengthMenu": 'Display <select>' +
                        '<option value="10">10</option>' +
                        '<option value="20">20</option>' +
                        '<option value="50">50</option>' +
                        '<option value="100">100</option>' +
                        '<option value="-1">all</option>' +
                        '</select> ids'
        }
} );

どのように解決するのですか?

バージョン1.10での解決方法

ここで完全な答えを探して見つからなかった後、私はこれを書きました(ドキュメントからのコードと、ここでのいくつかの答えを利用します)。

以下のコードは、少なくとも 3 文字が入力されるまで検索を遅らせるように動作します。

// Call datatables, and return the API to the variable for use in our code
// Binds datatables to all elements with a class of datatable
var dtable = $(".datatable").dataTable().api();

// Grab the datatables input box and alter how it is bound to events
$(".dataTables_filter input")
    .unbind() // Unbind previous default bindings
    .bind("input", function(e) { // Bind our desired behavior
        // If the length is 3 or more characters, or the user pressed ENTER, search
        if(this.value.length >= 3 || e.keyCode == 13) {
            // Call the API search function
            dtable.search(this.value).draw();
        }
        // Ensure we clear the search if they backspace far enough
        if(this.value == "") {
            dtable.search("").draw();
        }
        return;
    });