There is an error in jQuery 1.4.2 that makes the change event when the selection item is fired twice when using both the DOM event and the jQuery event, and this is only in IE7 / 8. Here is the test code:
<html>
<head>
<script src="http://code.jquery.com/jquery-1.4.2.js" type="text/javascript"></script>
<script type="text/javascript">
jQuery(document).ready(function() {
jQuery(".myDropDown").change(function() {
});
});
</script>
</head>
<body>
<select class="myDropDown" onchange="alert('hello');">
<option>1</option>
<option>2</option>
<option>3</option>
<option>4</option>
</select>
</body>
</html>
Update : Another look at the problem, in fact, this is a real problem with our application. Associating a live change event on a selector that does not even touch a select item with a DOM event also causes a double trigger.
<html>
<head>
<script src="http://code.jquery.com/jquery-1.4.2.js" type="text/javascript"></script>
<script type="text/javascript">
jQuery(document).ready(function() {
jQuery(".someSelectThatDoesNotExist").live("change", function() {
});
});
</script>
</head>
<body>
<select class="myDropDown" onchange="alert('hello');">
<option>1</option>
<option>2</option>
<option>3</option>
<option>4</option>
</select>
</body>
</html>
Ticket to the actual error: http://dev.jquery.com/ticket/6593
, ASP.NET, jQuery, , ( ) .
-, , ?