jQuery.on(“Change”,function(){})不触发动态创建的输入

内容来源于 Stack Overflow,并遵循CC BY-SA 3.0许可协议进行翻译与使用

  • 回答 (2)
  • 关注 (0)
  • 查看 (6596)

问题是,我有一些动态创建的输入标签集,我也有一个函数,意味着任何时候输入值改变。

$('input').on('change', function() {
  // Does some stuff and logs the event to the console
});

但是,.on('change')不会触发任何动态创建的输入,仅适用于加载页面时出现的项目。不幸的是,这使我留下了一点点的束缚,因为.on这是一种替代品.live().delegate()所有这些都是包装的.bind()

有没有其他人有这个问题或知道一个解决方案?

提问于
用户回答回答于

你应该为该on功能提供一个选择器:

$(document).on('change', 'input', function() {
  // Does some stuff and logs the event to the console
});

在这种情况下,它将按照你的预期工作。另外,最好指定一些元素而不是文档。

用户回答回答于

用这个

$('body').on('change', '#id', function() {
  // Action goes here.
});

所属标签

可能回答问题的人

  • 应用案例分享

    1 粉丝490 提问5 回答
  • Hyman.W

    15 粉丝0 提问3 回答
  • 桑先生

    14 粉丝0 提问3 回答
  • 找虫虫

    5 粉丝0 提问3 回答

扫码关注云+社区

领取腾讯云代金券

玩转腾讯云 有奖征文活动