我有一个hover
事件可以删除一个小按钮,并在它悬停时将其替换为完整的菜单栏。
我想做的是,如果鼠标没有悬停在菜单栏 ( this.element
) 上 5 秒(每次hover
发生事件时都会重置计时器),则会发生相反的情况。
this.button.on('hover', function(e){
t.admin_bar.show('slide', { 'direction': t.options.position }, 500);
t.button.hide('slide', { 'direction': t.options.position }, 500);
});
更新
在迄今为止提供的评论和答案的帮助下,我想出了这个。但是,即使mouseenter
和mouseleave
事件正在工作,clearTimout()
但似乎并没有,因为管理栏仍然被隐藏。
_create_events : function(){
var t = this; // This object
t.admin_bar = t.element
/** Capture when the mouse is hovered over the 'Show admin bar' button */
t.button.on('hover', function(e){
t._show_admin_bar();
t._set_timeout(); // Start a new timeout (to hide the admin bar if it's not hovered on)
});
/** Capture when the mouse is hovered over the admin bar */
t.admin_bar.on('mouseenter', function(e){
clearTimeout(t.timer); // Clear the existing timeout
});
/** Capture when the mouse leaves the admin bar */
t.admin_bar.on('mouseleave', function(e){
t._set_timeout(); // Restart the timout
});
}, // _create_events
_set_timeout : function(){
var t = this; // This object
t.timer = setTimeout(function(){
t._hide_admin_bar();
}, 5000);
}, // _timeout
_show_admin_bar : function(){
this.admin_bar.show('slide', { 'direction': this.options.position }, 500); // Show the admin bar
this.button.hide('slide', { 'direction': this.options.position }, 500); // Hide the 'Show admin bar' button
}, // _show_bar
_hide_admin_bar : function(){
this.admin_bar.hide('slide', { 'direction': this.options.position }, 500); // Hide the admin bar
this.button.show('slide', { 'direction': this.options.position }, 500); // Show the 'Show admin bar' button
}