Why does jQuery .change() not fire on radio button

2019-02-22 02:21发布

问题:

If I have several radio buttons of the same name, only one can be selected at any one time. When one becomes selected, any namesakes lose their selection. I'm intrigued as to why this doesn't constitute a .change() event for jQuery.

Hacking the $.change() function would be pretty drastic, but this doesn't seem to be reported as a bug — so I'm interested in finding out why this isn't the case.

Test below: I'd expect the two change events to fire whenever a radio is selected, but that isn't the case.

Here is the example: http://jsfiddle.net/XzmmW/

回答1:

If you think of a set of radio buttons like a select element, it becomes clear why it's unnecessary to fire a change event for the deselected radio button.

When you change the selected option in a select element, you get one change event (you wouldn't expect anything else), rather than one for the previously selected option, and another for the newly selected option.

As has already been mentioned, when one radio button is selected, no others in the same set can be, so it would be redundant to fire a second change event.

Also note that this is not specific to jQuery - the standard JavaScript change event works in exactly the same way.



回答2:

There is only 1 change event... you changed from "old selection" to "new selection".

Keep in mind that although you have multiple "elements" they are all part of the same form element (as defined by the name attribute).



回答3:

There is no need to fire an event for each radio button in a named group, when one is selected you know the others are not selected