jQuery on() 方法只能通过 childSelector 间接工作
jQuery on() method only works indirectly via childSelector
任何想法可能是代码的原因
$('body').on('click', '.btn_add', function(e) {alert("test");});
有效,但是
$('.btn_add').on('click', function(e) {alert("test");});
不?
谢谢
它是事件委托:
语法为:
$(staticparent).on(event, selector, fn);
在此语法中,selector
不是 DOM 的一部分,这意味着当您的页面加载时,此元素不在 DOM 中,但在执行一些 js 代码后,此.btn_add
元素添加到 DOM 中。 因此,页面加载时绑定的任何事件都不会为此元素注册。
因此,在您的情况下,如果.btn_add
是动态创建的,则必须将事件委托给最近的静态父项、正文或文档本身。
下面是未绑定在动态内容上的事件的测试用例。
$('button').on('click', function() {
$('<button/>', {
text: "Dynamic button"
}).appendTo('body');
alert(this.textContent);
})
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
<button>Static</button>
下面是绑定在动态内容上的事件的测试用例。
$('body').on('click', 'button', function() {
$('<button/>', {
text: "Dynamic button"
}).appendTo('body');
alert(this.textContent);
})
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
<button>Static</button>
相关文章:
- Javascript:selenium Web驱动程序isDisplayed()不工作
- jQuery UI自动完成突然停止工作
- AngularJS UI路由器不能像ng路由器那样工作
- HTML5音频加载和播放获胜'我不能在iPad上工作
- JavaScript打印功能使日历停止工作
- Javascript.getHours()工作不正常
- 为什么这在IE中的工作方式与在Firefox中不同
- 视频HTML没有'无法在Internet Explorer 11上工作
- 扩展移相器按钮类不工作
- Firebase迁移-简单的Firebase.set没有'不再工作了——旧的还是新的
- 谷歌地图不是以HTML显示,而是在JS Fiddle上工作
- 正在尝试使用if和else添加类,但无法正常工作
- Jquery FadeIn FadeOut 只工作一次
- Foreach无法在Typescript中工作
- 另一个ajax调用中的Jquery ajax调用在for循环中没有按预期工作
- 为什么不是't窗口.恢复正常工作吗?(javascript/jquery)
- JS可以在Chrome中工作,但不能在Firefox中工作
- ajaxToolkit PopupControlExtender不工作.过时的
- HTML标记在脚本标记中工作
- jQuery on() 方法只能通过 childSelector 间接工作