Jquery复选框更改function在IE 8中不起作用

我有以下jquery代码,点击一个复选框,我将显示一个弹出值。

除了在IE中,在所有其他浏览器中它按预期工作。 也就是说,在更改时,将选中复选框并打开弹出窗口。

但是在IE8中它没有被检查,但弹出窗口正确显示。

代码:

$('#TAndC').change(function(){ if( $('input[name="TAndC"]').is(':checked')) { $('#TandCBox').show(); var termsandcondition = GetEnum().TermsandConditionsPageId; var actionURL = '@Url.Action("ShowTAndC", "Account", new { isFromCheckBox = true })'; $('.popUpForm').load(actionURL); var msgBox = $('#terms').attr('href'); MaskMsgPopUp(msgBox); return false; } }); 

如果您的元素是checkbox而不是dropdown则仍然使用click

如果您的选择器指的是dropdown click是否需要支持IE8及更早版本。

看看为什么在下面。

根据MSDN for change / onchange ,在提交更改之前不会触发事件。

此外,当以编程方式更改值时,也不会触发事件。

报价:

提交内容时会触发此事件,而值不会更改时触发此事件。 例如,在文本框中,在用户键入时不会触发此事件,而是在用户通过保留具有焦点的文本框提交更改时触发。 此外,当控件也失去焦点时,此事件在onblur指定的代码之前执行。 当以编程方式更改选定对象的选定选项时,不会触发onchange事件。 已提交更改的文本选择。

要调用此事件,请执行以下操作之一:

  • 使用鼠标或键盘导航在选择对象中选择其他选项。
  • 更改文本区域中的文本,然后导航出对象。

如果您必须支持IE8及更早版本,那么您最好使用click事件,而不是当您释放鼠标并且选择了新选项时触发了该事件。

而不是.change使用下面的代码并尝试

 $(document).ready(function(){ $(document).on('click','#TAndC',click_function){ if( $('input[name="TAndC"]').is(':checked')) { $('#TandCBox').show(); var termsandcondition = GetEnum().TermsandConditionsPageId; var actionURL = '@Url.Action("ShowTAndC", "Account", new { isFromCheckBox = true })'; $('.popUpForm').load(actionURL); var msgBox = $('#terms').attr('href'); MaskMsgPopUp(msgBox); return false; } }); });