select2 - get current search text
Asked Answered
R

6

8

I'm using select2 and fetching available options from the server with this query function

var recipientsTimeout;
this.loadRecipients = function (query) {
    clearTimeout(recipientsTimeout);
    recipientsTimeout = setTimeout(function(){
        data.transmitRequest('lookupcontacts', { search: query.term }, function(resp){
            query.callback({ results: resp.items });
        });
    }, 500);
};

It uses our own ajax layer, and delays searching until the user stops typing, and it works fine. The only small issue is that if the user types some text, then immediately backspaces over it, my last timeout will still fire, and an ajax request will be fired, and ignored. This doesn't cause any problems, but it's less than optimal.

Is there any (preferably non-brittle) way to fetch whatever the current text is? It seems as though the query object sent in has an element property, which is a jQuery wrapper of the original hidden input I set select2 up with, but there's no direct way I can see to get the actual textbox that the user is typing in. Obviously I could inspect it and easily figure out the dom pattern and build up a selector from the hidden element back to what the user is typing in, but I really hate doing that, since the specific layout could easily change in a future version.

So what is the best way to get the currently entered text, so I could do a quick check on it when the setTimeout expires, and I'm about to run my ajax request.

Roussillon answered 13/1, 2014 at 17:25 Comment(0)
F
4

The hidden input element (where you initialize select2 on) gets a data property select2, which contains references to all elements, that are used by select2. So you could do something like this:

var hiddenInputSelector = '#e1',
    select2 = $(hiddenInputSelector).data('select2'),
    searchInput = select2.search;

if($(searchInput).val() === '')
    clearTimeout(recipientsTimeout);

This is not in the docs though, so it might change in the future.

Footworn answered 13/1, 2014 at 18:36 Comment(0)
I
21

I'm using 4.0.3 and the way I did it is this:

$("#mySelect2").data("select2").dropdown.$search.val()
Iritis answered 21/6, 2017 at 14:28 Comment(1)
For me it was $select.data('select2').selection.$search.val() in v4.0.12Merriott
F
4

The hidden input element (where you initialize select2 on) gets a data property select2, which contains references to all elements, that are used by select2. So you could do something like this:

var hiddenInputSelector = '#e1',
    select2 = $(hiddenInputSelector).data('select2'),
    searchInput = select2.search;

if($(searchInput).val() === '')
    clearTimeout(recipientsTimeout);

This is not in the docs though, so it might change in the future.

Footworn answered 13/1, 2014 at 18:36 Comment(0)
D
2

In select2 version 4.0.3 this works for me, whereas the others did not:

$('.select2-search__field')[0].value;
Derivation answered 24/12, 2016 at 0:1 Comment(0)
D
0

I do something like this to get the current search term:

list.data("select2").search[0].value;
Damages answered 30/4, 2014 at 14:35 Comment(0)
O
0

assume your element's id is #item_search fisrt we need to identify the modal open by select2:open then we can listen for the input so whenever user type something we can get the value

        $('#item_search').on('select2:open', function (e) {
            var searchText = $('.select2-search__field').val();
            $('.select2-search__field').on('input', function() {
                var searchText = $(this).val();
                console.log('Entered text:', searchText);
            });
        });

Orms answered 14/3, 2024 at 21:51 Comment(0)
M
0

Using Select2 4.1.0-rc.0 the jQuery path is:

$("#mySelect2").data('select2').dropdown.$search[0].value;
Muck answered 18/4, 2024 at 14:38 Comment(0)

© 2022 - 2025 — McMap. All rights reserved.