Pete Ravenscroft
Pete Ravenscroft

Reputation: 761

Jquery select change not firing

I need to capture when a select box changes, should be simple!

    $('#multiid').change(function(){
    alert('Change Happened');
});

But it does not work, I suspected the problem is that the select box does not exist on document ready it is created only if needed, so I created it empty in HTML, populated it with code as a test but that didn't work either.

function buildmulti(id,name,price) {
    // build action items for action bar
    var optlist = $('<select></select>').attr('id', 'multiid').attr('name', 'multiid');
    optlist.append('<option value="0">Select Size</option>');
    $.each(option, function(index, val) {
        if(val.prodID *1  == id * 1) {
            v = val.ID;
            fprice = price * 1 + val.pricechange * 1;
            t = name + ' - ' + val.variation +  ' - ' + currency + (fprice).toFixed(2);
            optlist.append('<option value="' + v + '">' + t + '</option>');
        }
    })
    $('#addbasket').append(optlist);
};

it's probably another bracket out of place, but I can't find it!

Upvotes: 71

Views: 190587

Answers (7)

Deepak
Deepak

Reputation: 313

You can try the following, it should work

$(document).on('change','#fieldid',function(){
    alert('change triggered');
});

Upvotes: 1

Melistraza
Melistraza

Reputation: 45

For me perfectly fork this code.

$('#dom_object_id').on('change paste keyup', function(){
    console.log($("#dom_object_id").val().length)
});

Key event for .on() function is "paste" to get changes dynamically

Upvotes: 0

Prince Patel
Prince Patel

Reputation: 3060

You can fire chnage event by these methods:

First

$('#selectid').change(function () {
    alert('This works');
}); 

Second

$(document).on('change', '#selectid', function() {
    alert('This Works');
});

Third

$(document.body).on('change','#selectid',function(){
    alert('This Works');
});

If this methods not working, check your jQuery working or not:

$(document).ready(function($) {
   alert('Jquery Working');
});

Upvotes: 11

dsf
dsf

Reputation: 19

This works for me!

$('#<%= ddlstuff.ClientID %>').change(function () {
    alert('Change Happened');
     $('#<%= txtBoxToClear.ClientID %>').val('');
});

Upvotes: 1

Dhaval Marthak
Dhaval Marthak

Reputation: 17366

Try

 $(document).on('change','#multiid',function(){
    alert('Change Happened');
});

As your select-box is generated from the code, so you have to use event delegation, where in place of $(document) you can have closest parent element.

Or

$(document.body).on('change','#multiid',function(){
    alert('Change Happened');
});

Update:

Second one works fine, there is another change of selector to make it work.

$('#addbasket').on('change','#multiid',function(){
    alert('Change Happened');
});

Ideally we should use $("#addbasket") as it's the closest parent element [As i have mentioned above].

Upvotes: 205

Rituraj ratan
Rituraj ratan

Reputation: 10388

$(document).on('change','#multiid',function(){
  // you desired code 
});

reference on

Upvotes: 3

Anil kumar
Anil kumar

Reputation: 4177

Try this

$('body').on('change', '#multiid', function() {
    // your stuff
})

please check .on() selector

Upvotes: 11

Related Questions