首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >动态绑定新行为

动态绑定新行为
EN

Stack Overflow用户
提问于 2014-06-16 14:51:45
回答 3查看 54关注 0票数 1

我有一个HTML:

代码语言:javascript
复制
<div class="bold knowmore login" id="j-6">
<span>...</span>
</div>

这个jQuery:

代码语言:javascript
复制
$(function(){
  $(".login").on("click", function(){ 
     console.log('login clicked!');
     $(".bold.knowmore").removeClass("login").addClass("displayAdvert");
  });

  $(".displayAdvert").on("click",function(){
    console.log("display was clicked!");
  }); 
});

但产出总是:

登录点击!

但是,由于某种原因,HTML被更新了,但是事件总是调用单击登录。有人知道我怎么解决这个问题吗?

EN

回答 3

Stack Overflow用户

回答已采纳

发布于 2014-06-16 14:56:11

使用事件委托,因为您动态地添加了一个类:

代码语言:javascript
复制
$(function(){
  $(document).on("click",".login", function(e){ 
      e.preventDefault();
     console.log('login clicked!');       $(".bold.knowmore").removeClass("login").addClass("displayAdvert");
  });

  $(document).on("click", '.displayAdvert',function(e){
      e.preventDefault();
    console.log("display was clicked!");
  }); 
});

演示

票数 2
EN

Stack Overflow用户

发布于 2014-06-16 14:55:10

您需要使用-一个委托-事件接近

您正在动态地分配.displayAdvert类,因此需要使用带有动态元素委托的.on方法:

我想您的故事中有一个静态的父级,所以使用它的ID:

代码语言:javascript
复制
$(function(){
  $(".login").on("click", function(){ 
     console.log('login clicked!');
     $(".bold.knowmore").removeClass("login").addClass("displayAdvert");
  });

  $("#parent").on("click", ".displayAdvert", function(){
    console.log("display was clicked!");
  }); 
});

http://api.jquery.com/on/#direct-and-delegated-events

票数 4
EN

Stack Overflow用户

发布于 2014-06-16 14:56:49

对于动态创建的元素,可以使用如下内容:

代码语言:javascript
复制
$(document).on("click", ".displayAdvert", function() {
    console.log("display was clicked");
});
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/24246447

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档