重构以避免 setTimeout 函数
Refactor to avoid the setTimeout function
我想附加一个事件处理程序,当将鼠标悬停在项目上时,它将在它附加到的项目周围放置一个边框。如果可能的话,我想避免使用函数setTimeout()。有人有什么想法吗?感谢你引导我到一个可以处理这样的事情的有用框架。
下面的代码是我找到如何执行以下操作的唯一方法。我需要这样做的原因是因为我将抓取元素内部的 html 并从 db 值中替换它。这是我的代码:
var color;
$(document).ready(function(){
attachMouseEnter();
// This is not resetting. How do I make it so I can reset this?
function attachMouseEnter(){
$('.editable').mouseenter(function(){
console.log($(this));
$(this).wrap('<span class="test"></span>')
$(this).css('border', '1px solid red');
});
window.setTimeout(attachMouseOut(), 1000);
}
// this is making it so I cannot grab the element and attach a handler to it.
function attachMouseOut(){
$('.editable').mouseout(function(){
var orginal = $(this);
$(this).css("border", "0px");
$(this).parent().replaceWith(orginal.parent().html());
window.setTimeout(attachMouseEnter(), 1000);
});
}
});
您不必一次又一次地调用事件处理程序。只要叫一次就足够了..
var color;
$(document).ready(function(){
$('body').on('mouseenter','.editable',function(){
console.log($(this));
$(this).wrap('<span class="test"></span>')
$(this).css('border', '1px solid red');
});
$('body').on('mouseout','.editable',function(){
var orginal = $(this);
$(this).css("border", "0px");
$(this).parent().replaceWith(orginal.parent().html());
});
});
相关文章:
- setTimeout函数能否在其前面的代码执行之前激发
- JS:setTimeout函数的UI计数
- Jasmine:测试setTimeout函数会抛出一个错误
- Javascript/Jquery setTimeout 函数不适用于长 html
- 如何让 setTimeout 函数运行,然后停止使用循环
- 有没有办法覆盖 setTimeout 函数,使其使用微秒而不是毫秒
- setTimeout函数的精确计时
- Javascript-为什么不是't此setTimeout函数正在工作
- 阻止页面重新加载时的setTimeout函数
- 2 setTimeout函数第一个清除第二个javascript
- 如何在 setInterval/setTimeout 函数中按名称调用函数
- Javascript SetTimeOut函数不知怎么不起作用
- Javascript setTimeOut 函数与 .net 中 Windows 应用程序的计时器不匹配
- Javascript setTimeout 函数保持运行
- 当 ajax 返回 1 时如何删除 setTimeout 函数
- setTimeout 函数比它应该的更快
- Javascript:我的setTimeout函数由于第三方而不起作用
- 如何或在哪里将javascript settimeout函数添加到CSS垂直下拉菜单
- 在 javascript 对象中使用方法的值以在 setTimeout 函数中使用
- 如何阻止此 setTimeout 函数运行