如何使用 javascript 中的 mouseover 事件删除我在 javascript 中创建的 DOM 节点?

Posted

技术标签:

【中文标题】如何使用 javascript 中的 mouseover 事件删除我在 javascript 中创建的 DOM 节点?【英文标题】:How do I remove DOM nodes that I created in javascript using mouseover events in javascript? 【发布时间】:2019-04-07 07:00:00 【问题描述】:

因此,html 显示了一个区域,其中随机放置了一百个小框。我使用 javascript 来制作小盒子。 HTML 中还有一个按钮,我在 js 中编写了一个按钮,每次单击它时都会多生成一百个小框。我的问题是,我希望每次将鼠标悬停在每个小盒子上时都能消失,最好使用“this”命令来做到这一点。是我做错了什么,还是 javascript 在创建新的 HTML 元素后无法与它们交互?

这是我的代码:

 window.onload = function()
 createBoxes();
 $("myButton").observe("click", createBoxes);
 var divvy = $("container");
 var pars = divvy.getElementsByTagName("p")
 pars.onmouseover = destroyBoxes;


function destroyBoxes (event)
var divvy = $("container");
var pars = divvy.getElementsByTagName("p")
if (event.type == "mouseover")   
pars.removeChild(This);






function createBoxes()

var colors = ["red", "green", "grey", "blue", "orange", "yellow"];
for (i=0;i<=99;i++)
var newP = document.createElement("p");
var top = Math.floor( Math.random() *400 ) + "px";
var left = Math.floor( Math.random() *400 ) + "px";
newP.style.top  = top;
newP.style.left  = left;
newP.style.backgroundColor = colors[ Math.floor( Math.random() *6 )];
$("container").appendChild(newP);
      var divvy = $("container");
      var pars = divvy.getElementsByTagName("p")
      pars.onmouseover = destroyBoxes;
    
    

【问题讨论】:

嘿@BuddyCodes,我得去尝试event.target,而不是destroyBoxes() 函数中的This。祝你好运,上帝保佑! @ChrisHappy 非常感谢!在修改了你的建议之后,我能够让它完美地工作。我希望你现在和我一样好,哈哈 【参考方案1】:

“尝试在destroyBoxes() 函数中使用event.target 而不是This。”

话虽这么说...自己找到解决方案的工作做得很好!

如果有兴趣,这是我使用 jQuery 函数的解决方案。

window.onload = function() 
  createBoxes();
  $(".myButton").on("click", createBoxes); // Use class selector
  //Find all `p`s in `container`
  //$pars.on('hover', destroyBox);



function destroyBox(event) 

  var $target = $(event.target);
  // The 'if' statement is redundant. Only run the function if wanted.
  //if (event.type == "mouseover")  
    $target.remove();
  //



function createBoxes() 
  var colors = ["red", "green", "grey", "blue", "orange", "yellow"];
  
  var newPs = [];
  
  for (i = 0; i < 100; i++) 
    var top = Math.floor(Math.random() * 400),
        left = Math.floor(Math.random() * 400),
        color = colors[Math.floor(Math.random() * 6)];
        
    var $newP = $('<p></p>').css(top: top, left: left, backgroundColor: color);
    newPs.push($newP);
    
  
  
  var $container = $(".container").append(newPs); // Use class selector
  $container.find('p').on('mouseover', destroyBox);
.container 
  position: relative;


p 
  position: absolute;
  width: 10px;
  height: 10px;
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.0/jquery.min.js"></script>

<div>
<button type="button" class="myButton">Click for more!</button>
</div>

<div class="container"></div>

【讨论】:

~即时满足:点击按钮直到填满屏幕。慢慢删除它们...

以上是关于如何使用 javascript 中的 mouseover 事件删除我在 javascript 中创建的 DOM 节点?的主要内容,如果未能解决你的问题,请参考以下文章