How do I implement onchange of <input type="text"> with jQuery?

JqueryInputOnchange

Jquery Problem Overview


<select> has this API. What about <input>?

Jquery Solutions


Solution 1 - Jquery

As @pimvdb said in his comment,

> Note that change will only fire when the input element has lost focus. > There is also the input event which fires whenever the textbox updates > without it needing to lose focus. Unlike key events it also works for > pasting/dragging text.

(See documentation.)

This is so useful, it is worth putting it in an answer. Currently (v1.8*?) there is no .input() convenience fn in jquery, so the way to do it is

$('input.myTextInput').on('input',function(e){
 alert('Changed!')
});

Solution 2 - Jquery

You can use .change()

$('input[name=myInput]').change(function() { ... });

However, this event will only fire when the selector has lost focus, so you will need to click somewhere else to have this work.

If that's not quite right for you, you could use some of the other jQuery events like keyup, keydown or keypress - depending on the exact effect you want.

Solution 3 - Jquery

I would suggest using the keyup event something like below:

$('elementName').keyup(function() {
 alert("Key up detected");
});

There are a few ways of achieving the same result so I guess it's down to preference and depends on how you want it to work exactly.

Update: This only works for manual input not copy and paste.

For copy and paste I would recommend the following:

$('elementName').on('input',function(e){
 // Code here
});

Solution 4 - Jquery

Here's the code I use:

$("#tbSearch").on('change keyup paste', function () {
    ApplyFilter();
});

function ApplyFilter() {
    var searchString = $("#tbSearch").val();
    //  ... etc...
}

<input type="text" id="tbSearch" name="tbSearch" />

This works quite nicely, particularly when paired up with a jqGrid control. You can just type into a textbox and immediately view the results in your jqGrid.

Solution 5 - Jquery

There is one and only one reliable way to do this, and it is by pulling the value in an interval and comparing it to a cached value.

The reason why this is the only way is because there are multiple ways to change an input field using various inputs (keyboard, mouse, paste, browser history, voiceinput etc.) and you can never detect all of them using standard events in a cross-browser environment.

Luckily, thanks to the event infrastructure in jQuery, it’s quite easy to add your own inputchange event. I did so here:

$.event.special.inputchange = {
    setup: function() {
        var self = this, val;
        $.data(this, 'timer', window.setInterval(function() {
            val = self.value;
            if ( $.data( self, 'cache') != val ) {
                $.data( self, 'cache', val );
                $( self ).trigger( 'inputchange' );
            }
        }, 20));
    },
    teardown: function() {
        window.clearInterval( $.data(this, 'timer') );
    },
    add: function() {
        $.data(this, 'cache', this.value);
    }
};

Use it like: $('input').on('inputchange', function() { console.log(this.value) });

There is a demo here: http://jsfiddle.net/LGAWY/

If you’re scared of multiple intervals, you can bind/unbind this event on focus/blur.

Solution 6 - Jquery

<input id="item123" class="firstName" type="text" value="Hello there" data-someattr="CoolExample" />

$(".firstName").on('change keyup paste', function () {
   var element = $(this);
   console.log(element);
   var dataAttribute = $(element).attr("data-someattr");
   console.log("someattr: " + dataAttribute );
});

I recommend use this keyword in order to get access to the entire element so your are able do everything you need with this element.

Solution 7 - Jquery

The following will work even if it is dynamic/Ajax calls.

Script:

jQuery('body').on('keyup','input.addressCls',function(){
  console.log('working');
});

Html,

<input class="addressCls" type="text" name="address" value="" required/>

I hope this working code will help someone who is trying to access dynamically/Ajax calls...

Solution 8 - Jquery

If you want to trigger the event as you type, use the following:

$('input[name=myInput]').on('keyup', function() { ... });

If you want to trigger the event on leaving the input field, use the following:

$('input[name=myInput]').on('change', function() { ... });

Solution 9 - Jquery

$("input").change(function () {
    alert("Changed!");
});

Solution 10 - Jquery

$("input").keyup(function () {
    alert("Changed!");
});

Solution 11 - Jquery

You can do this in different ways, keyup is one of them. But i am giving example below with on change.

$('input[name="vat_id"]').on('change', function() {
	if($(this).val().length == 0) {
		alert('Input field is empty');
	}
});

NB: input[name="vat_id"] replace with your input ID or name.

Solution 12 - Jquery

You could simply work with the id

$("#your_id").on("change",function() {
    alert(this.value);
});

Solution 13 - Jquery

This worked for me. If field with name fieldA is clicked or any key entered it updates field with id fieldB.

jQuery("input[name='fieldA']").on("input", function() {
	jQuery('#fieldB').val(jQuery(this).val());
});

Solution 14 - Jquery

You could use .keypress().

For example, consider the HTML:

<form>
  <fieldset>
    <input id="target" type="text" value="Hello there" />
  </fieldset>
</form>
<div id="other">
  Trigger the handler
</div>

The event handler can be bound to the input field:

$("#target").keypress(function() {
  alert("Handler for .keypress() called.");
});

I totally agree with Andy; all depends on how you want it to work.

Attributions

All content for this solution is sourced from the original question on Stackoverflow.

The content on this page is licensed under the Attribution-ShareAlike 4.0 International (CC BY-SA 4.0) license.

Content TypeOriginal AuthorOriginal Content on Stackoverflow
QuestionomgView Question on Stackoverflow
Solution 1 - JqueryiPadDeveloper2011View Answer on Stackoverflow
Solution 2 - JqueryGregView Answer on Stackoverflow
Solution 3 - JqueryAndrewView Answer on Stackoverflow
Solution 4 - JqueryMike GledhillView Answer on Stackoverflow
Solution 5 - JqueryDavid HellsingView Answer on Stackoverflow
Solution 6 - JqueryNoWarView Answer on Stackoverflow
Solution 7 - JqueryVinithView Answer on Stackoverflow
Solution 8 - JqueryUsman AhmedView Answer on Stackoverflow
Solution 9 - JqueryGeorg SchöllyView Answer on Stackoverflow
Solution 10 - JqueryPhuView Answer on Stackoverflow
Solution 11 - JqueryRokan NashpView Answer on Stackoverflow
Solution 12 - JqueryNerdy SidView Answer on Stackoverflow
Solution 13 - JquerySeefanView Answer on Stackoverflow
Solution 14 - Jquerykcho0View Answer on Stackoverflow