我已经将单击事件切换到一个节点上,并且我也想将双击事件切换到它上面。但是,当我双击它时,它只会触发单击事件。
那么,我该如何同时设置这两个事件?
我已经将单击事件切换到一个节点上,并且我也想将双击事件切换到它上面。但是,当我双击它时,它只会触发单击事件。
那么,我该如何同时设置这两个事件?
你需要自己完成 "双击检测" 功能。
以下方式可能有效:
var clickedOnce = false;
var timer;
$("#test").bind("click", function(){
if (clickedOnce) {
run_on_double_click();
} else {
timer = setTimeout(function() {
run_on_simple_click(parameter);
}, 150);
clickedOnce = true;
}
});
function run_on_simple_click(parameter) {
alert(parameter);
alert("simpleclick");
clickedOnce = false;
}
function run_on_double_click() {
clickedOnce = false;
clearTimeout(timer);
alert("doubleclick");
}
这里有一个可用的JSFiddle
如需了解计时器应使用的延迟时间的更多信息,请查看此处:如何在元素上同时使用onclick和ondblclick?
$("#test-id").bind("click dblclick", function(){alert("hello")});
适用于单击和双击
编辑--
我认为这是不可能的。我试图做类似于这样的事情。
$("#test").bind({
dblclick: function(){alert("Hii")},
mousedown: function(){alert("hello")}
});
但是不经过单击无法达到双击。我尝试了鼠标按下但它没有提供任何解决方案。
我基本上使用了Jeremy D.相同的逻辑。
然而,在我的情况下,更加简洁的解决方法是使用匿名函数和稍微慢一点的双击超时时间:
dblclick_timer = false
.on("click", function(d) {
// if double click timer is active, this click is the double click
if ( dblclick_timer )
{
clearTimeout(dblclick_timer)
dblclick_timer = false
// double click code code comes here
console.log("double click fired")
}
// otherwise, what to do after single click (double click has timed out)
else dblclick_timer = setTimeout( function(){
dblclick_timer = false
// single click code code comes here
console.log("single click fired")
}, 250)
})
var clicked = false,
dblClicked = false,
clickTimer;
function onClick(param){
console.log('Node clicked. param - ',param);
};
function onDoubleClick(param){
console.log('Node Double clicked. param - ',param);
};
function clickCheck(param){
if (!clicked){
clicked = true;
clickTimer = setTimeout(function(){
if(dblClicked){
onDoubleClick(param);
}
else if(clicked){
onClick(param);
}
clicked = false;
dblClicked = false;
clearTimeout(clickTimer);
},150);
} else {
dblClicked = true;
}
};
你需要跟踪双击事件,如果不是双击,则执行单击操作。 尝试这个。
<p id="demo"></p>
<button id='btn'>Click and DoubleClick</button>
<script>
var doubleclick =false;
var clicktimeoutid = 0;
var dblclicktimeoutid = 0;
var clickcheck = function(e){
if(!clicktimeoutid)
clicktimeoutid = setTimeout(function(){
if(!doubleclick)
performclick(e);
clicktimeoutid =0;
},300);
}
var performclick =function(e){
document.getElementById("demo").innerHTML += 'click';
}
var performdblclick = function(e)
{
doubleclick = true;
document.getElementById("demo").innerHTML += 'dblclick';
dblclicktimeoutid = setTimeout(function(){doubleclick = false},800);
};
document.getElementById("btn").ondblclick = performdblclick;
document.getElementById("btn").onclick=clickcheck;
</script>