向每个获得clientX的元素添加一个函数
Add a function to every element that gets clientX
我在做一个拖放操作。当用户获取元素时,我需要为每个元素添加dragenter
的事件侦听器。在该侦听器函数中,我需要它在鼠标移动到该元素上时获取并保存clientX
。我遇到的问题是,它获取第一个元素的鼠标位置,并为每个其他元素保持相同的位置。我该如何解决这个问题?
if(editor_children[i].nodeType != 3)
{
editor_children[i].addEventListener("dragenter", function(event){
if(event.target.id !== e.target.id) event.target.className= event.target.className + " highlight";
position= event.clientX;
last_over= event.target.id;
console.log("Mouse: " + e.clientX + " Position: " + position + " Last Element: " + last_over);
})
editor_children[i].addEventListener("dragleave", function(event){
event.target.className= event.target.className.replace(' highlight', '');
});
}
这就是为什么我不是JavaScript的超级粉丝。无论如何,这个问题是由我在循环中创建一个函数引起的,所以它每次都使用相同的值,而不是一个变量值。我只是通过运行JShint学到的。此外,我还必须清除拖放调用之间的函数,以避免存储数据的问题。这很难解释,但我明白了。
相关文章:
- 我可以在json对象中添加一个函数吗
- 如何在JQuery函数中定义一个值,然后调用另一个函数并使用该值
- 是否可以将一个函数输入连接到另一个函数调用的文本
- 在另一个函数中使用变量this
- 在另一个函数成功结束后调用该函数
- mongoose.connect undefined不是一个函数
- 监听器必须是一个函数
- 使用JS函数来使用另一个函数的语法?node.js
- 如何取消object.prototypes javascript的一个函数
- 从Chrome扩展名中的popup.html文件在background.js文件中运行一个函数
- 嵌套到另一个函数中的Fancybox函数;不起作用
- 如何在javascript中使用不止一个函数
- jQuery-在页面加载时执行一个函数
- jquery UI draggable:UI.children不是一个函数
- jQuery Mobile Undefined不是一个函数
- 如何在php中创建一个函数,该函数与文本区域一起工作,通过输入类似[color:red]的内容来打印具有等效颜色的文本
- javascript函数将数据添加到屏幕,但随后被另一个函数覆盖
- JS异常:animate不是一个函数
- 如何将一个函数附加到一个不存在的元素上
- JavaScript/jQuery-添加添加和删除类与下一个函数之间的延迟