Search table with input fields in cells

Search table with input fields in cells

alzamboalzambo Posts: 38Questions: 17Answers: 1

Hi,

following this example, how can apply a search filter to columns with input field (Age and Position)?

Thank you,
Alex

This question has an accepted answers - jump to answer

Answers

  • allanallan Posts: 63,695Questions: 1Answers: 10,500 Site admin

    Hi Alex,

    You would need to implement a custom search plug-in.

    Allan

  • alzamboalzambo Posts: 38Questions: 17Answers: 1

    Hi Alan and thank you for your answer.
    I'm testing it and cannot access values of input fields in column 9

            $('input[name=filterNumeroFattura]').on('keyup', function() {
                $.fn.dataTable.ext.search.push(function(settings, data, dataIndex) {
                    console.log(data[9]);
                    return false;
                });
                table.draw();
                $.fn.dataTable.ext.search.pop();
            });
    

    data[9] returns always empty value.
    How can I access it?

  • allanallan Posts: 63,695Questions: 1Answers: 10,500 Site admin
    Answer ✓

    Try something along the lines of:

    var dtApi = null;
    
    $.fn.dataTable.ext.search.push(function(settings, data, dataIndex) {
            if ( ! dtApi ) {
                    dtApi = new $.fn.dataTable.Api( settings );
            }
    
            console.log( dtApi.row( dataIndex ).node() );
            return false;
    });
    
    $('input[name=filterNumeroFattura]').on('keyup', function() {
        table.draw();
    });
    

    I would suggest not adding a new filter to the array on every key press - although the push / pop was a clever way of doing it. But it wouldn't be present if your user sorted the table for example.

    The dtApi variable is used to access the DataTables API, and I've stored it in a variable so it doesn't need to be created on every single filter call.

    Allan

This discussion has been closed.